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Preface 


La revolution Drupal 

Qu’y a-t-il de commun entre Mediapart, Rue89 et le gouvernement 
fran^ais ? Entre deux sites d ’information independants et le portail officiel 
du pouvoir ? Entre la libre production de nouvelles indociles par les pre- 
miers et la diffusion controlee des communications ministerielles par le 
second ? Entre les deux pure players qui travaillent a inventer la presse 
numerique de demain et les dispositifs gouvernementaux qui accompa- 
gnent le bouillonnement democratique du Net ? Juste un nom, qui est au 
ressort technologique et editorial des uns et de l’autre : Drupal. Depuis juin 
2009, sous un premier ministre, Francois Fillon, qui se revendique comme 
« un vrai geek », le portail du gouvernement a en effet migre de SPIP a 
Drupal, adoptant le systeme de gestion des contenus (CMS ou Content 
Management System en version originale) utilise par Rue89 et Mediapart. 

Cette unanimite technologique, par-dela des objectifs editoriaux diffe- 
rents - en somme, information contre communication -, confirme la 
success story de Drupal depuis son invention tatonnante, il y a moins de 
dix ans, par un informaticien beige, Dries Buytaert. Etudiant a l’Univer- 
site d’Anvers, il en est venu a creer Drupal, dont la version 1.0 est sortie 
debut 2001, a partir du bricolage en 1999 d’un systeme de messagerie 
interne pour sa residence etudiante. Ce point de depart n’est pas indiffe- 
rent, tant il confirme l’esprit originel de Drupal : loin dune vision close 
de la technique, repliee sur elle-meme et fermee aux non-inities, la com- 
munaute d’utilisateurs, la facilite de ses usages et la commodite de ses 
pratiques sont le premier souci de Drupal, ce CMS que son inventeur 
definit comme un « assembleur rapide de site web » ( rapide website 
assembler). 
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Dans l’univers du logiciel libre ( Open Source ), Drupal, modeste logiciel 
de forum a l’origine, est done rapidement devenu lun des systemes de 
gestion de contenus les plus populaires. Aux Etats-Unis, en 2008 
comme en 2007, il a ete classe premier au concours du meilleur CMS 
dans la categorie en acces libre. Avec plusieurs milliers de contributeurs 
de par le monde, sa communaute est de plus en plus active et inventive, a 
l’image de sa derniere conference internationale tenue a Paris, en 
septembre 2009. C’est dire si ce precis pedagogique et pratique, sans 
equivalent jusqu’alors en langue fran^aise, tombe a pic alors que Drupal 
offre desormais une version tres mature, la 6.13, et tandis que s’annonce 
deja la tres prometteuse version 7. 

Le succes de Drupal s’explique d’abord parce qu’il repond a une attente 
vitale, tant elle est au coeur de la revolution democratique dont le nume- 
rique est potentiellement le moteur, si nous nous en donnons les moyens 
et les instruments. A fheure de l’avenement du media personnel, il s’agit 
de permettre a chaque lecteur d'etre un auteur potentiel, de construire 
des agoras oil s’elabore le savoir dans le croisement des competences et 
des experiences, et de faciliter par consequent un dialogue direct de qua- 
lite entre chaque auteur et ses lecteurs. 

De ce point de vue, l’expose methodique de Yoran Brault a pour pre- 
miere qualite de ne jamais s’ecarter de l’essentiel, autrement dit de ne pas 
perdre de vue les deux principes fondamentaux de Drupal : d’abord, 
mettre les contenus au centre - leur integrite, leur conservation, leur 
amelioration, leur partage et leur circulation ; ensuite, se placer du point 
de vue de l’utilisateur, qu’il soit contributeur chevronne ou potentiel, de 
ses commodites d’acces et de ses facilites de participation. 

Facilite, rapidite, simplicity, fiabilite sont les valeurs maitresses - et l’on 
comprend aisement qu’elles sont philosophiquement democratiques : pas 
d’aristocratie technique, pas de privilege savant, pas d elite proprietaire. 
Aussi les conseils pratiques qui font le sel de ce manuel ont-ils l’immense 
interet de signaler les pieges qui peuvent en eloigner, qu’il s’agisse de 
fausses manoeuvres ou de distorsions excessives (par exemple, les recom- 
mandations sur l’usage des caches). Car Drupal est evidemment un sys- 
teme complexe, et a ce titre suppose rigueur, precaution et doigte. 

Tout informaticien, meme amateur, n’a pas besoin d’avoir lu Edgar Morin, 
notre theoricien fran^ais de la « complexity », pour savoir d’experience que 
complexe, ici, ne veut pas forcement dire complique, et peut done s’appuyer 
sur des exposes simples et limpides. Mais, sous ce mot synonyme d’interde- 
pendance et d’interaction, se cache une ambition extremement precieuse, 
dont l’actuelle revolution industrielle introduit les bouleversements dans 
notre votre quotidien, sans que nous les ayons encore accompagnes des 
revolutions democratiques et intellectuelles qu’ils appellent. 
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C’est tout simplement la realisation pratique de cet ideal pascalien, oil la 
partie est indissociable du tout, et inversement le tout dans la partie, 
comme le definissait de fa<;on imagee et poetique Pascal lui-meme dans 
ses Pensees : « Toutes choses etant causees et causantes, aidees et 
aidantes, mediates et immediates, et toutes s’entretenant par un lien 
naturel et insensible qui lie les plus eloignees et les plus differentes, je 
tiens impossible de connaitre les parties sans le tout, non plus que de 
connaitre le tout sans connaitre particulierement les parties. » 

Tel est le defi intellectuel que nous lance Drupal, et l’exercice salvateur 
auquel il nous oblige. Ici, ideal technologique et ideal democratique se 
rejoignent et s’imbriquent. Tandis que le systeme modulaire de Drupal 
oblige a penser en meme temps le tout et les parties, leur logique et leur 
dialectique - leur « dialogique », dirait Morin -, la dimension participa- 
tive des plates -formes de conte nus qu’il permet de construire oblige a 
defaire l’ancienne etancheite entre auteurs et lecteurs, journalistes et 
publics, specialistes et citoyens, et par consequent invite a repenser 
ensemble, dans la solidarity et dans la liberte, les roles, statuts et actions 
des uns et des autres. 

Dans le dernier tome de La Methode , monument qui me semble etre 
l’oeuvre morale indissociable de la revolution numerique, tant elle la 
reflechit et l’accompagne, Edgar Morin insiste sur l’auto-ethique, 
comme vertu individuelle et comme vertu sociale, qu’appelle cette com- 
plexity nouvelle des reseaux, de leur virtualite technologique et de leurs 
usages sociaux. « L’exces de complexity, ecrit-il, detruit les contraintes, 
distend le lien social, et la complexity, a son extreme, se dissout dans le 
desordre. Dans ces conditions, la seule sauvegarde d une tres haute com- 
plexity se trouve dans la solidarity vecue, interiorisee en chacun des 
membres de la societe. Une societe de haute complexity devrait assurer 
sa cohesion non seulement par de justes lois, mais aussi par responsabi- 
lite, solidarity, intelligence, initiative, conscience de ses citoyens. Plus la 
societe se complexifiera, plus la necessity de l’auto-ethique s’imposera. » 

Si je cite longuement cette mise en garde, c’est parce qu’elle me semble 
parfaitement refleter la demarche de Yoran Brault, son esprit et son exi- 
gence. La technique appelle une ethique. Et, par dessus tout, une 
ethique du savoir, entre precision et transmission, rigueur et partage. 

Edwy Plenel 
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Avant-propos 


Linformation ecrite a toujours circule dun auteur vers ses lecteurs. A 
son origine, le Web ne fut qu un media supplemental ajoute a la longue 
descendance de rimprimerie de Gutenberg. Mais l’expansion de cet 
outil a partir des annees 2000 l’a tres vite conduit a depasser le cadre des 
medias traditionnels, par la creation de nouvelles possibility, inexis- 
tantes jusqu alors : pour la premiere fois, chaque lecteur est aussi un 
auteur potentiel, et un dialogue direct interactif peut s ’instaurer entre un 
auteur et son lectorat. Cette premiere phase de ce qu’on appellera plus 
tard le Web 2.0 n a cesse par la suite de s’etendre a de nouveaux 
domaines d utilisation, dont le plus marquant reste celui des reseaux 
sociaux. C’est pour prendre en charge ces contenus de plus en plus foi- 
sonnants que sont apparus les CMS ( Content Management System) ou 
systemes de gestion des contenus. 

Ces outils succederent aux technologies traditionnelles HTML ou PHP 
qui demandaient, pour creer une page web, des competences techniques 
pas forcement a la portee de toute personne devant publier sur Tlnternet. 
Grace aux CMS, les redacteurs disposent desormais d un outil « cles en 
main », leur permettant de s'affranchir des contraintes techniques pour 
publier leurs contenus en temps voulu, sans intervention systematique 
d un informaticien. Qui plus est, de tels outils facilitent le travail collabo- 
rate, ainsi que la gestion des contenus provenant de Tinteraction avec les 
lecteurs (commentaires, etc.). Ainsi le CMS est-il devenu l’outil le plus 
indique pour creer rapidement des sites web de tous usages, du journal en 
ligne au site institutionnel, en passant par le blog ou l’intranet. 
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Parmi tous les CMS disponibles sur le marche, il en est un qui se 
demarque dans la foule : Drupal. Defini par son createur comme un 
« assembleur rapide de site web », Drupal est le systeme de gestion de con- 
tenus le plus souple qui soit. Construit sous forme modulaire autour d un 
noyau de tres petite taille, il delegue en effet chaque fonctionnalite a un 
module separe, ce qui signifie, en theorie, que ce logiciel peut etre etendu a 
1’infini. Ainsi, entre outil pret a l’emploi et plate-forme de developpement, 
il permet de gerer la quasi-totalite des sites web, quel que soit leur type. 

Enfin, pour ne rien gacher, Drupal est un logiciel libre, tout comme ses 
modules. Il beneficie du travail de toute une communaute de deve- 
loppeurs, traducteurs, utilisateurs et redacteurs de documentation, qui 
contribuent tous a ameliorer encore et toujours le logiciel. Ainsi, outre la 
gratuite, il propose un outil adaptable a tous les besoins, puisque tout un 
chacun peut modifier son code source pour obtenir un logiciel sur mesure. 


Pourquoi ce livre ? 

Ce livre a pour objectif de vous apprendre a concevoir, a creer puis a 
deployer un site web avec Drupal. De Installation et du parametrage a 
la mise en production, sans oublier la methodologie, tous les aspects sont 
abordes pour vous permettre de maitriser l’outil au sein de son contexte 
- le Web d’aujourd’hui. 

Il ne s’adresse cependant pas aux developpeurs connaissant deja bien 
Drupal et desireux d’etendre son fonctionnement a travers la realisation 
de modules. En effet, il ne s’agit pas dun manuel de developpement, 
mais d un guide pratique destine a vous accompagner, quel que soit votre 
niveau, vers la production dun site moderne et fonctionnel. 


A qui s’adresse-t-il ? 

Cet ouvrage s’adresse done a toute personne cherchant a decouvrir ou a 
approfondir sa connaissance du CMS Drupal : 

• le decideur, ou encore le chef de projet, qui aura a gerer un chantier 
sous Drupal, et qui doit comprendre ce quest un CMS, ce quest 
Drupal et comment il fonctionne ; 

• le developpeur PHP qui doit construire un site avec Drupal et qui trou- 
vera ici les outils et les techniques lui permettant de realiser sa tache ; 

• toute personne qui cherche a comprendre le fonctionnement interne 
de Drupal pour construire son propre site. 
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Structure de I’ouvrage 

Le chapitre 1 de ce livre explique ce quest un CMS [Content Manage- 
ment System ), son origine, sa philosophie et son usage. 

Le chapitre 2 est une transposition de ce que nous aurons appris des 
CMS sur le systeme Drupal, en detaillant autant que possible ses lacunes 
et ses points forts. 

Le chapitre 3 traite de la definition de notre besoin. II s’agit d une etape 
purement methodologique, dont fobjectif est d’aboutir a une vision 
claire de ce que nous allons realiser par la suite. A Tissue de ce travail, 
nous ne devrions plus nous poser de questions sur le « quoi », afin de 
nous concentrer pleinement sur le « comment ». 

Le chapitre 4 detaille la phase indispensable de creation d’une plate- 
forme de developpement dediee a Drupal. Celle-ci va nous permettre 
d’experimenter les notions abordees dans les chapitres suivants, de 
maniere simple et sans risque. Les etapes d’installation d’Apache, 

MySQL et Drupal y sont detaillees pour les environnements Windows 
et GNU/Linux. 

Le chapitre 5 est notre premier contact avec Drupal, a travers son sys- 
teme d’administration. Ce chapitre se conclut par T installation de notre 
premier module. 

Le chapitre 6 nous permet ensuite d’aller plus en profondeur dans 
Tadministration, pour apprendre a gerer une notion tres importante dans 
un CMS : les utilisateurs. Nous decouvrirons ici tous les aspects de la 
creation de comptes utilisateur, ainsi que la mise en place de roles per- 
mettant de donner a chacun des droits particuliers. 

Dans le chapitre 7, nous arrivons au coeur de ce quest un CMS : la crea- 
tion de contenu. Nous commencerons par aborder la notion de type de 
contenu , pour ensuite creer notre premier article et en gerer tous les 
aspects : modification, commentaires, etc. 

Le chapitre 8 nous emmene un cran plus loin dans le domaine de la 
creation de contenu, en abordant des notions plus complexes de taxo- 
nomie, de contenus hierarchises et de gestion des historiques de modifi- 
cation. Nous y apprendrons surtout a creer nos propres types de contenu 
evolues grace au module CCK, et a les exploiter avec le module Views. 

Avec le chapitre 9, nous sortons du domaine du contenu pour passer 
dans celui du contenant, et plus particulierement de la structuration des 
informations disponibles sur chaque page de notre site. Nous decouvri- 
rons ici comment Drupal se revele etre un puissant outil de presentation, 
capable d’afficher de maniere planifiee nimporte quel type d’informa- 
tion sur nimporte quelle page. 
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Le chapitre 10 se place a la croisee des chemins entre contenu et conte- 
nant, pour nous permettre de rendre notre site multilingue. Nous etudie- 
rons ici comment decliner notre site en plusieurs langues, tant au niveau 
de Tinterface que des contenus eux-memes. 

Notre site etant maintenant structure, le chapitre 11 nous fait entrer 
dans le domaine du graphisme et des couleurs, en nous permettant de 
transformer radicalement fapparence de notre site, de la simple configu- 
ration des themes existants jusqu aux techniques de realisation d un 
theme totalement personnalise. 

Le chapitre 12 traite de l’ajout d’outils transversaux a Drupal. Notre site 
etant a present joliment presente et capable d’integrer tous les contenus 
que nous souhaitons, il ne reste done plus qua y ajouter les dizaines de 
fonctions qu un visiteur est en droit d’attendre d un site moderne : PDF, 
Gravatar, notifications, OpenID, bulletin d’informations (newsletter), 
etc. 

Avec le chapitre 13, nous quittons le domaine du contenu pour entrer 
dans celui de la maintenance d un site Drupal, en examinant plus parti- 
culierement les possibilites d’automatisation des taches courantes. Nous 
y aborderons notamment le travail en equipe a travers la realisation de 
flux de travaux ( workflows ). 

Le chapitre 14 offre une ouverture vers d’autres possibilites a travers la 
realisation de notre premier module pour Drupal. Un module simple et 
facile a mettre en oeuvre, qui nous permettra de comprendre les meca- 
nismes fondamentaux de Drupal. 

Le chapitre 15 est faboutissement de notre travail. Notre site est pret, il 
a ete teste, et nous apprendrons comment mettre a jour chacun de ses 
composants pour finalement l’amener a la vie sur un serveur de produc- 
tion. A Tissue de ce chapitre, notre site sera en ligne, pret a recevoir le 
succes qu il merite. 

Le chapitre 16 est une conclusion en forme d’ouverture a ce que nous 
promet la prochaine version de Drupal, la version 7. 
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Rappels utiles sur les CMS 


Les CMS ont revolutionne Fapproche de publication 
sur le Web, s’adaptant en permanence aux besoins crees 
par l’instantaneite et l’interactivite du Web dit 2.0. 

Avant de commencer avec Drupal, il est bon de revenir 
sur les principes de base qui forment un CMS : separation 
du fond et de la forme, classification des contenus, gestion 
des contenus dynamiques et des commentaires, droits et roles 
des utilisateurs, etc. 


SOMMAIRE 

► Qu'est-ce qu'un CMS ? 

► Qu'apporte un CMS compare 
a un site traditionnel ? 

► La separation 
fond/presentation 

► Que puis-je faire d'un CMS ? 
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L’histoire du Web 

Le Web n a pas toujours ete un endroit des plus conviviaux, loin de la. 
Cinq ans apres sa naissance en 1990, la Toile etait essentiellement com- 
posee de volumineux ensembles de fichiers HTML, pimentes de scripts 
rediges dans quelques langues absconses. En 1995, l’emergence du 
couple PHP/MySQL a donne naissance a une seconde generation de 
sites, certes beaucoup plus riches et dynamiques, mais qui n en restaient 
pas moins des machineries construites sur mesure et gardees bien hors 
de portee des non-specialistes. 


Culture La premiere page web 

Cest en 1989 que Tim Berners-Lee 1 alors employe au CERN 2 , propose a 
la communaute scientifique une approche novatrice du partage de 
^information visant a relier entre elles des sources de donnees distri- 
butes sur ^Internet de maniere arbitraire et non hierarchisee. Le Web et 
ses hyperliens etaient nes. 

Les hyperliens en eux-memes ne sont pas une invention de Berners-Lee 
mais de Ted Nelson, qui en 1965 cherchait lui aussi un moyen non 
lineaire d'organiser ^information. Pour la petite histoire, le brevet a 
navigue de societe et societe jusqu'a aboutir dans le portefeuille de Bri- 
tish Telecom qui chercha meme a faire un proces pour violation de 
brevet (!) aux fournisseurs d'acces americains en 2002 3 . 

En 1990, Robert Cailliau arrive dans le projet et collabore a la proposi- 
tion definitive du « WorldWideWeb: Proposal for a HyperText Project ». 
Les bases du Web avec des concepts aujourd'hui aussi basiques qu f URL, 
HTML, ou HTTP sont inventes. 

L'equipe du CERN va ensuite ecrire le premier service HTTP (poetique- 
ment nomme nxoc01.cern.ch) et le navigateur associe, le WordWi- 
deWeb, ensuite rebaptise Nexus. La toute premiere page HTML est 
finalement mise en ligne le 13 novembre 1990 4 , et en 1991, le projet 
devient mondial avec la mise en place d 7 un second serveur au SLAC 
(accelerateur de Stanford). Un an plus tard, ce sont vingt-six sites qui 
sont en ligne, en partie grace a Larrivee du celebre service HTTP NCSA. 

1 . http://fr.wikipedia.org/wiki/Tim_Berners-Lee 

2. http://fr.wikipedia.org/wiki/CERN 

3. http://www.foruminternet.org/specialistes/veille-juridique/actualites/british-telecom- 
revendique-des-droits-sur-l-hyperlien.html 

4. http://www.w3.Org/History/1 9921 1 03-hypertext/hypertext/WWW/Link.html 


A cette epoque, le processus classique pour modifier son site consistait a 
saisir les textes dans son coin, pour les transmettre ensuite a des deve- 
loppeurs qui se chargeaient, en quelques jours, de mettre le tout en 
ligne... Et s’il s’agissait de modifier un aspect plus visuel, les jours se 
transformaient vite en semaines. 
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Ce mode de travail fonctionna pendant un temps, mais le succes du Web 
et la complexity des sites allant grandissante, deux problemes commen- 
cerent a se poser de maniere recurrente : 

• Comment modifier la forme dun site sans systematiquement 
remettre en cause sa conception ? 

• Comment modifier le fond d un site sans systematiquement passer 
par des pro du Web ? 

C’est dans ce contexte qu’ont ete jetees a la fin des annees 1980 les pre- 
mieres bases dun systeme de gestion des contenus (en anglais CMS pour 
Content Management System). A cette epoque, les CMS etaient autant une 
theorie qu une serie de bonnes pratiques apparues au fil du temps, que les 
concepteurs d’outils tels que Typo3 tenterent de mettre en coherence. 

Dans la suite de ce chapitre, nous allons etudier les concepts cles com- 
muns a tous les CMS, sans nous attacher a une quelconque implementa- 
tion. C’est une etape probablement fastidieuse pour ceux qui sont deja 
rompus a ce type d’outillage, aussi peuvent-ils se rendre directement au 
chapitre suivant. II est cependant important de poser le plus clairement 
possible les bases qui nous serviront tout au long de cet ouvrage : 

• Qu’est-ce qu un contenu ? 

• Comment et pourquoi est-il separe de sa forme visuelle ? 

• Comment ces contenus sont-ils classes ? 

• Quels processus permettent de les modifier ? 


Le fond et la forme 

Avant les CMS, fapparence d une page et ce quelle racontait etaient 
deux choses intimement liees. Ainsi, changer la couleur du titre ou 
changer le texte du titre etait une seule et meme operation car tout etait 
confine en un seul et meme document : le fichier HTML ou PHP. 

Le principe fondateur des CMS est de considerer qu un document doit 
etre separe avec d un cote un contenu , et de l’autre une presentation de ce 
contenu. Pour bien comprendre ces deux concepts, prenons fexemple 
dun article de votre quotidien prefere. Lorsque vous achetez ce journal 
en kiosque, vous avec sous les yeux une version papier de cet article. II 
s’agit a forigine dun simple texte fourni par le journaliste qui a ete mis 
en page par toute une equipe de maniere a rendre sa lecture la plus 
agreable possible. Si vous allez sur le site web de ce meme journal, vous y 
retrouverez l’article mais presente cette fois-ci de sorte que sa lecture soit 
adaptee a un ecran. Les deux articles ne se ressemblent pas dans la 
forme, mais sont bien issus du meme texte ecrit par le meme journaliste. 
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Dans le vocabulaire CMS, le journaliste a redige un contenu qui a ete 
publie sous deux presentations distinctes : papier et Web. 

Pour aller un peu plus loin, un CMS impose une vision structuree de ce 
contenu. Car ce n est pas tout de dire qu un contenu est un simple texte, 
encore faut-il que le CMS puisse identifier sa structure : il considerera 
ainsi notre article comme un assemblage d’elements tels que titre, sous- 
titre, illustration, auteur, etc. Cette vision lui permet des lors d’appliquer 
une presentation specifique a chaque element. 

Pour synthetiser ces concepts clefs, nous pouvons donner les definitions 
suivantes : 

• Un contenu est un ensemble structure d’informations (titre, auteur, 
etc.) sans aucune notion de mise en page ou de mise en forme. 

• La presentation d'un contenu applique un style visuel a chaque element 
du contenu de sorte a en obtenir une version publiable. Un meme 
contenu peut ainsi avoir plusieurs presentations, generalement adap- 
tees a un media donne (papier, Web, etc.). 

Sachant cela, il semble evident que selon la nature de notre contenu 
- article de fond ou simple depeche -, ce dernier ne contiendra pas les 
memes informations de base. Une depeche contiendra par exemple une 
« date de la depeche » qui n a pas lieu d’etre dans un article de fond. De 
meme, un article de fond contiendra un auteur qui n aurait que peu de 
sens dans une depeche. C’est en reponse a ce constat que le CMS intro- 
duit la notion de type de contenu. 

Un type de contenu definit la liste des informations qui constituent le 
contenu. Chaque information est caracterisee par son nom (ex. illustra- 
tion ou encore titre) et son type (ex. image ou texte). 
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Taxonomie des contenus 

Une fois tous ces contenus crees, tout le jeu consiste a pouvoir les 
retrouver facilement. Tout CMS digne de ce nom integre le concept de 
recherche dite plein texte , qui fonctionne peu ou prou comme les 
moteurs de recherche sur flnternet. Mais cette approche est loin d’etre 
satisfaisante si l’on desire obtenir par exemple l’ensemble des documents 
traitant de « systeme d’exploitation ». 

Le second concept introduit par les CMS vous permet done de 
« ranger » vos contenus par mots-cles libres ou par taxonomie. Trop sou- 
vent confondu avec l’idee un peu simple de categories , la taxonomie est en 
realite un ensemble de mots-cles (appeles taxons) appartenant a un meme 
domaine et relies entre eux par un lien de hierarchie. 
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Dans l’exemple donne ci-dessous, nous avons une (petite) taxonomie des 
domaines de competence d une societe de conseil en management. Ainsi, 
si nous rattachons un contenu au taxon Recrutement, il appartiendra de 
facto au taxon Ressources Humaines et Domaines de competence et res- 
sortira du lot si Ion fait une recherche sur lun de ces trois termes. 



Figure 1-1 

Un exemple de taxonomie 


Tous ces criteres de recherche sont bien sur combinables, permettant par 
exemple d’obtenir la liste de tous les contenus de type Article ecrits par 
lutilisateur Marine, apres le 15 janvier 2007 et traitant de Systeme et 
reseaux. 


Du contenu statique au contenu dynamique 

Au cours des deux premieres generations de sites web, le changement de 
la moindre virgule sur la page dun site vous obligeait a recourir a f inter- 
vention dun specialiste. C’etait un processus long et frustrant pour les 
personnes en charge d’ecrire les contenus. 


Culture D'ou vient le terme Web 2.0 ? 

Le terme « Web 2.0 » est a mettre au credit de Dale Dou- 
gherty de la societe O'Reilly Media 1 . Lors d'une conference 
en 2004, Dale cherche par cette numerotation a posteriori 
(il n f y a jamais eu de numerotation des versions du Web) a 
faire prendre conscience a son auditoire de la difference 
d'approche fondamentale entre le Web d'avant I'explosion 
de la bulle Internet et le nouveau Web. Une difference qui 
trouve son point de depart concret en 2001, au lendemain 
de la crise de ^Internet, avec la naissance de Wikipedia et la 
prise de pouvoir des utilisateurs qui s'en suivit. 


1. http://www.eutech-ssii.com/ressources/! 


Avec Wikipedia, pour la premiere fois le contenu 
« monte ». Les documents ne sont pas ecrits par des 
« tetes connues et reconnues », mais par les internautes 
eux-memes, chacun avec leur savoir, leurs competences, 
dans un mode purement collaboratif et ouvert. Pour 
caracteriser cette (r)evolution, le magazine Wired va 
meme jusqu'a inventer un nouveau terme : le 
« crowdsourcing », litteralement la delegation de la cons- 
truction du contenu aux internautes devenus d'un coup, 
pour la premiere fois, des « utilisateurs ». 


www.frenchpdf.com 


- Rappels utiles sur les 










Drupal 6 - Concevoir et deployer ses applications 


£ 


Les CMS ont radicalement change cette approche en permettant aux 
utilisateurs de modifier dynamiquement leurs contenus et surtout de 
publier directement ceux-ci sur le Web. 

Le CMS vous permet d un simple die d editer le contenu qui se cache derriere 
la page que vous etes en train de visualiser. Des que vous validez vos modifica- 
tions, le contenu dans sa nouvelle presentation vous est alors renvoye. 


Figure 1-2 

La base d'un CMS, le cycle de vie d'un contenu 


Contenu de type 
« Mission » 

Titre : 


£|Campayoe de recrutement.. 


Description : 


La mission a consist e en la 
mise en place d'une 
campagne de recrutement 
d'une epuipe exploitation... 


Date : 

^25/01/2009 


Visualisation 


► 


Armee 

Campagnc dc 
recrutement... 
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Edition 


La mission a consists 
en la mise en place 
dune campagne de 
recrutement dune 
equipe exploitation... 

j/ 



Lorsque ce contenu vous semble correct, il est alors possible de le publier 
sur flnternet d un simple clic. 

Cette approche simple et intuitive de modification du contenu est un 
changement significatif dans le rapport entre hauteur et le media. Enfin 
decharge de la relation utilisateur/technicien, il est alors libre de pro- 
duire a son rythme. Cette mutation a eu pour resultat fapparition d une 
troisieme classe d’acteurs du Web : les contributeurs. Cette nouvelle cate- 
gorie d ’intervenants a notamment fait le succes d un CMS mondiale- 
ment connu, Wikipedia, et done du Web 2.0. 


Des droits et des roles 

Cependant, cette nouvelle classe d’acteur amene aussi de nouveaux 
besoins en matiere de gestion des droits. Il est en effet rarement souhai- 
table de laisser a n importe quel visiteur la possibilite de modifier le con- 
tenu dun site. Les CMS disposent done d'une approche complete de la 
gestion des droits, combinant permissions et roles. 

• Une permission est un droit simple portant sur une operation du 
CMS. 

• Un role est quant a lui un ensemble nomme de permissions. 

Par exemple, le role nomme Ecrivain contiendra la permission « creer un 
nouveau contenu de type article » mais pas forcement la permission 
« rendre un contenu visible ». Un role nomme Correcteur, quant a lui, ne 
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possedera pas « creer un contenu » mais seulement « modifier un con- 
tenu existant », etc. 

Une fois ces roles definis, le CMS permet de les attribuer a des utilisa- 
teurs qui devront s’identifier pour en beneficier. 

Pour completer cette approche collaborative de creation de contenu, un 
CMS autorise la definition d’etats par type de contenu, permettant ainsi 
la mise en place de flux de travaux (en anglais, workflow). Un contenu 
peut ainsi passer de 1’etat Nouveau a fetat En attente de correction, puis 
Corrige, puis Publie. II est des lors possible de definir des roles ayant la 
permission de faire passer un contenu dun etat a un autre. 

Les CMS les plus aboutis protegent leur contenu de toute alteration 
accidentelle ou maligne en mettant en place un systeme d’historique, 
chaque modification du contenu induisant la creation d une nouvelle 
version. II sera ainsi possible de remonter dans le temps pour revenir a 
une version anterieure. 


Les commentaires 

Les CMS proposent une serie de services lies au contenu. La majorite 
d’entre eux consiste a prevenir lutilisateur d une nouveaute sur le site par 
courriel, ou encore par flux RSS. 


Culture Les commentaires et le Web 2.0 

Le crowdsourcing, anime par des utilisateurs disposant d'une « identite 
numerique », carburant du phenomene Wikipedia, est devenu reellement 
populaire avec les fameux commentaires. Les utilisateurs parlent aux utili- 
sateurs, fournissant ainsi de maniere incidente aux proprietaires d f un site, 
un contenu volumineux et surtout... gratuit. Les utilisateurs s f expriment, 
communiquent et forment ainsi le troisieme et surement le plus impor- 
tant concept cle du Web 2.0 : les reseaux sociaux. 

Cette denomination un tantinet ronflante de reseau social decrit nean- 
moins assez bien une nouvelle forme de communication transversale. 
Non seulement les utilisateurs ne regoivent plus ^information d f en haut, 
mais en plus ils la produisent et la partagent. Le circuit de ^information 
devient ainsi enomnement plus complexe que pour n'importe quel 
media preexistant : verticalement ( bottom up) et horizontalement. Et un 
exemple plus qu'evocateur de ces reseaux sociaux, de cette communica- 
tion transversale : les blogs. 


Parmi ces services satellites, la possibilite laissee aux visiteurs de publier 
leurs commentaires est de loin la plus revolutionnaire. 
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En effet, dans les premieres periodes du Web, finteraction auteur/lecteur 
fonctionnait comme pour les medias traditionnels. La communication 
emanait toujours d une source unique vers de multiples destinataires : du 
journaliste vers les lecteurs, du webmestre vers les visiteurs, etc. 

Avec ses commentaires, le lecteur emprunte un canal de communication 
inedit en direction de Tauteur, c’est-a-dire de la source de Tinformation. 
Par une demarche censee lui permettre uniquement d’exprimer son opi- 
nion, il vient en realite enrichir le contenu initial et par consequent, 
nourrir son auteur. 

Pris dans la theorie des CMS, les commentaires ne sont finalement 
quune maniere de modifier dynamiquement un contenu parent en 
venant s’y accrocher. Ces commentaires sont done des contenus a part 
entiere qu’il est possible d’exploiter comme n importe quel autre type de 
contenu. Ils auront done eux aussi un fond (le texte du commentaire) et 
une forme (leur apparence visuelle), la possibility d'etre edite dynami- 
quement et d’apparaitre sous differentes formes. 


Un CMS, mais pour quoi faire ? 

Les CMS resultent de fexperience cumulee des sites de precedentes 
generations. II nest done pas surprenant quils apparaissent aujourd’hui 
comme des outils de creation rapide de sites, convenant a peu pres a tous 
les usages. 

• Un journal en ligne, car le CMS dispose de tous les outils pour per- 
mettre la mise en ligne d une activite journalistique classique : ce type 
de site exploitera particulierement la taxonomie, la multiplication des 
vues par contenu, la creation de types de contenu specifiques (depe- 
ches, articles, dossier, etc.). 

• Le blog et le site personnel sont eux aussi de bons candidats pour les 
CMS, dont ils utilisent la simplicity de mise en oeuvre, la rapidite 
d edition et de mise en ligne et les divers services permettant la syndi- 
cation. 

• Les forums utilisent depuis longtemps des CMS specialises 
(ex. phpBB), mais les CMS plus generalistes se pretent egalement 
bien a fexercice. 

• Les sites Intranet exploitent massivement les outils de collaboration 
offerts par les CMS. 

• Les sites institutionnels reprennent nombre d’avantages des CMS, 
avec un accent particulier sur la separation fond/forme, permettant 
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une mise en oeuvre ou un changement rapide d une charte graphique, 
sans mettre en peril la structure et le contenu. 

Ce ne sont la que quelques exemples, car en realite, il serait plus simple 
d’etablir la liste des sites qui n’ont rien a gagner a utiliser un CMS. 
Generalement, il s’agit plus duplications que de sites web. Par exemple, 
si vous cherchez a creer pour votre societe un service de messagerie avec 
une interface accessible par le Web, l’utilisation dun CMS ne presente 
que peu d ’interet. 

La diversite des CMS existant sur le marche est bien a l’image de cette 
quasi -universality d usage. A titre d’exemple, si Ton se limite aux logi- 
ciels libres toutes plate-formes confondues, il existe plus d’une centaine 
de CMS dont 80 en PHP. Ce nombre tombe a 35 pour les CMS dits 
generalistes, c’est-a-dire ceux qui ne sont pas concpis specifiquement 
pour des forums, des annuaires, du reseau social, du groupware , etc. 

Mais si vous lisez ce livre, c’est que vous avez deja une petite idee de 
celui qui vous interesse, et nous allons maintenant voir en detail ce que 
Drupal - ce CMS hors normes - a de si particulier. 


En resume 

• CMS veut dire Content Management System. En fran^ais, cela se tra- 
duit par systeme de gestion des contenus ou SGC. 

• Pour un CMS, tout est contenu : article, page, commentaire, etc. 

• Un CMS permet de creer tout type de site web des lors qu il y a 
manipulation de contenu (blog, catalogue de produits, etc.) 

• Un CMS permet de faire une separation stricte entre les informa- 
tions d un contenu et leur presentation visuelle. 

• Un CMS permet un travail collaboratif sur le contenu quil gere. 
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Drupal, un CMS extensible 


Drupal nest pas un CMS comme les autres. Partant d un 
systeme somme toute traditionnel, il n a cesse d’evoluer 
pendant pres de dix ans, avec pour seule idee de ne jamais 
fermer aucune possibility tout en recherchant une efficacite 
maximale. De ce paradoxe a decoule une architecture atypique 
et performante, a mi-chemin entre le logiciel « cles en main » 
et la plate-forme de developpement, permettant ainsi de 
construire tout type de site web, depuis le simple blog 
personnel jusqu’au plus moderne des reseaux sociaux. 


SOMMAIRE 

► ^architecture atypique 
de Drupal 

► Comment Drupal interprete 
les fondamentaux d'un CMS 

► Comment Drupal utilise 
les bases de donnees 

► Les performances et la 
« dimensionnabilite » 
de Drupal 

► La licence de Drupal 
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L’ architecture de Drupal 

Drupal fait partie de la famille des CMS libres a vocation generaliste 
ecrits en PHP. Mais presente ainsi, il n est au fond qu’un parmi trente- 
cinq de ses freres et soeurs. Ce qui amene inevitablement a la question 
suivante : Qua done Drupal de si par ticulier ? 

Dries, l’initiateur de ce logiciel, definit Drupal comme un « assembleur 
rapide de site web ». Cette image peut sembler un peu rapide, mais 
definit cependant sa capacite a creer rapidement des sites tres varies 
(portail, blog, site institutionnel) tout en ne faisant - et e’est important 
de le preciser - que bien peu de concessions par rapport aux des besoins 
d’origine. Le secret de cette souplesse reside dans le mot « assemblage » 
donne dans fexpression de Dries, qui nous renvoie directement a l’archi- 
tecture ultra-modulaire de Drupal. 


Culture L'histoire de Drupal 

L'histoire de Drupal commence en 1999 lorsque Dries Buytaert, alors etudiant a I'universite 
d'Anvers, cherche a creer un reseau sans fil pour partager sa connexion ADSL (un luxe pour 
lepoque) avec ses compagnons de chambree. Vint alors le besoin d'un site web pour partager 
le statut de ce reseau. 

Lorsque Dries est diplome, le site est transfere sur I'lnternet sous le nom drop.org. Ce drole de 
nom est simplement le fruit d'une erreur de frappe de Dries qui voulait en fait acheter le 
domaine dorp.org (« village » en neerlandais). L'erreur ne posa pas de probleme a la commu- 
naute de passionnes des technologies du Web qui commengait a se creer autour de ce site 
pour I'experimenter et le faire evoluer. II y travaillerent jusqu'a ce que les sources soient libe- 
rees en 2001 sous le nom de « Drupal » (le mot « drop », en neerlandais, se pronongant 
« druppel », etait trop complique a prononcer pour des anglophones). 

En octobre 2004, la version 4.5 de Drupal est livree et forme les contours « definitifs » de ce 
que nous en connaissons aujourd'hui. 
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Modularity ne signifie pas simplement extensibility. La majorite des 
CMS modernes sont extensibles. Generalement formes dun corps 
dense integrant la gestion du contenu, des commentaires, du rendu 
visuel, des flux, etc., il est toujours possible de leur adjoindre quelques 
greffons (ou plug-ins , ou encore composants) dont le but sera d’amener 
telle ou telle nouvelle fonctionnalite. Dans cette approche, le CMS, qui 
forme un ensemble monolithique, ne peut etre etendu que par des 
« ouvertures » qui auront ete prealablement pratiquees. 

Il est done delicat d’etendre ce genre de produit de maniere organique. 
En effet, que se passe-t-il lorsqu un developpeur veut changer un aspect 
auquel ne correspond aucune ouverture ? Il attend generalement avec 
impatience que sorte une nouvelle version du produit, disposant des 
nouvelles portes dont il a besoin. Ou pire, il perce lui meme ses propres 
portes, fragilisant ainsi dangereusement l’edifice. 
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Figure 2-1 

^architecture de Drupal 


Des son origine, Drupal a pris une direction radicalement differente. 

Son architecture interne consiste en un noyau de tres petite taille, ne 
contenant que les fonctionnalites essentielles (gestion des requetes 
HTTP, du cache, etc.), et deleguant l’ensemble des traitements fonda- 
mentaux a des modules. Les modules vont a leur tour deleguer certains 
traitements a d’autres modules, et ainsi de suite jusqu’a remonter un 
resultat au noyau. Pour les aider dans cette tache, Drupal leur fournit 
dans ce noyau une bibliotheque tres complete de fonctions regroupees 
par thematique appelees API (FormAPI, SchemaAPI, MenuAPI, etc.). 

Ce dernier point permet aux modules d'etre eux aussi de tres petite taille 
mais surtout de contenir le moins de bogues possible. 

C’est ainsi que pour Drupal, chacune des fonctions fondamentales dun 
CMS - comme la gestion du contenu, des commentaires ou encore des 
fichiers attaches - est prise en charge par un module autonome. La con- 
sequence directe de cette approche est un systeme extremement robuste 
qu’il est difficile de destabiliser. 

L’autre implication de cette architecture est que chaque fonctionnalite de 
Drupal a ete con^ue des l’origine pour pouvoir etre modifiee ou rem- 
placee par un module. Partie integrante de tous les traitements, le champ 
d’action du module est done beaucoup plus large que celui dun simple 
greffon, ce qui explique en grande partie la multitude de modules 
Drupal disponibles aujourd’hui. Vous desirez authentifier vos utilisateurs 
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sur un service LDAP ? II existe un module pour cela. Vous voulez 
acceder a votre contenu via le protocole webDAV ? II existe egalement 
un module. Vous desirez importer un contenu a partir d un fichier CSV, 
monter une boutique en ligne, integrer un geolocalisation, ajouter des 
recherches par facette ? Des modules existent pour toutes ces taches. 

Au moment de la redaction de ce livre, et rien que pour la version 6 de 
Drupal, le depot drupal.org comptait plus de 3 400 modules lib res et done 
gratuits, repartis sur une trentaine de domaines fonctionnels. Dans les 
rares cas oil vous ne trouveriez pas votre bonheur, la creation d un nou- 
veau module est d une grande simplicity pour qui possede quelques con- 
naissances basiques en PHP. 

En resume, cette architecture modulaire est l’atout majeur de Drupal, lui 
octroyant une grande robustesse alliee a une extreme souplesse, et lui 
permettant de coller a tous les usages. Drupal est done effectivement une 
machine a assembler rapidement des sites web. 

Cet atout nest cependant pas sans danger. Nous y reviendrons plus en 
detail par la suite, mais sachez que tous ces modules ne sont pas - loin de 
la - de qualite et de maturite egales. II est done primordial de choisir 
avec grand soin les modules que vous integrerez a votre site. Cela con- 
siste generalement a exclure les modules qui ne sont pas encore declares 
comme stables, a etudier avec interet la liste des anomalies non resolues, 
et a consulter les statistiques fournies sur le site drupal.org qui indique pour 
chaque module le nombre de sites rutilisant effectivement, ce qui cons- 
titue un bon indicateur de son niveau dutilite. 


Un contenu au centre de tout 

Comme vous pouvez l’imaginer, Drupal evolue tres vite avec une telle 
architecture, ce qui peut, a juste titre, inquieter celui qui se preoccupe de 
la perennite de son site, et particulierement du contenu qu’il contient, sa 
veritable richesse. 

En realite, ce risque a ete circonscrit depuis le debut par un principe 
garantissant la conservation systematique des donnees d’une version a 
fautre de Drupal. Les contenus saisis avec Drupal 4 continuent d'etre 
« lisibles » avec Drupal 6 et le seront avec le futur Drupal 7. Votre inves- 
tissement est ainsi protege. 

En contrepartie, aucune compatibility ascendante n est assume pour les 
modules eux-memes. En d’autres termes, un module qui fonctionne avec 
Drupal 6 n est pas assure de fonctionner avec Drupal 7. C’est done aux 
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developpeurs des modules qu’incombe la responsabilite de la migration 
de leur projet d’une version a l’autre. 

Cette approche permet a Drupal d’evoluer tres rapidement dans le sens 
de la technologie tout en assurant la continuity de ce qui vous est le plus 
cher : vos donnees. 

Maintenant rassure sur la perennite des donnees, vous pouvez legitime- 
ment vous demander ce qui se passera pour votre site si les developpeurs 
de modules ne suivent pas le rythme des versions de Drupal. C’est en 
effet un risque a garder en tete, mais qui lui aussi a ete prevu. 

En effet, la communaute Drupal fournit des mises a jour regulieres pour 
les deux dernieres versions majeures du CMS : la version courante, et la 
version precedente. Au rythme d’une version annuelle, cette organisation 
laisse done un an pour permettre aux developpeurs de migrer leurs 
modules, ce qui dans la pratique est largement suffisant. Vous concernant, 
cela implique qu a partir du moment oil vous avez mis en oeuvre Drupal, 
vous avez deux ans devant vous pour envisager sereinement la migration. 
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Les caracteristiques majeures de Drupal 

La liberte des formats d’entree 

Comme nous favons vu, un CMS se caracterise par la separation entre le 
fond et la forme. Drupal applique ce principe a la lettre en n imposant a 
aucun moment le format des contenus que vous saisissez. 

Pour y parvenir, l’outil se repose sur un concept de « chaine de 
transformations » appele « format d’entree » qui va, par traitements suc- 
cesses, produire un contenu au format XHTML exploitable sur le Web. 

Vous avez ainsi la possibility de definir autant de formats d’entree que vous 
le desirez, ainsi que chacune de leurs etapes de transformation appelees 
« filtres ». Les filtres etant fournis par des modules, vous pouvez soit vous 
contenter de ceux presents en standard, soit en aj outer de nouveaux - vous 
permettant par exemple de prendre en charge des syntaxes plus exotiques 
(syntaxe Wiki ou phpBB), des outils de correction de syntaxe HTML, des 
filtres maquillant les adresses de courriel pour eviter les pourriels, etc. 

Les chaines de filtres ainsi constituees peuvent ensuite etre appliquees 
selon les droits des utilisateurs et les types de contenus rediges. 


www.frenchpdf.com 


- Drupal, un CMS extensible 


Drupal 6 - Concevoir et deployer ses applications web 


Un moteur de theme performant 

Une fois le contenu formate au standard XHTML, le moteur de theme 
de Drupal intervient. S’appuyant sur un jeu de modeles (templates 
PHP), ce module d’une grande souplesse rend possible toutes les fantai- 
sies visuelles, comme faire varier Tapparence du site selon la section oil 
f on se trouve, le type de contenu affiche, le type de liste de resultats, ou 
encore un schema specifique d’URL. 

Au-dela de sa puissance, le point interessant de ce moteur est qu’il n a 
pas ete pense pour le developpeur PHP, mais pour lmfographiste, que 
Ton appelle le « themeur ». II est done tres simple a mettre en oeuvre sans 
pour autant connaitre les structures internes de Drupal, l’essentiel du 
parametrage se faisant par la nomenclature des modeles. 

Le code des pages produit par Drupal est particulierement propre et 
optimise. Globalement, sans parametrage et avec les themes standards, 
Drupal fabrique des pages parfaitement compatibles avec les standards 
XHTML/CSS, avec en prime une excellente accessibility. 

Enfin, il est important de noter que les URL de Drupal sont facilement 
indexables par les moteurs de recherche et sont totalement parametra- 
bles. Ce point interessera notamment tout public sensibilise aux proble- 
matiques de referencement. 

Une taxonomie native 

Contrairement a d’autres CMS populaires qui limitent la categorisation 
des contenus a seulement deux niveaux, Drupal integre un moteur de 
taxonomie permettant des classements et des recherches sur un nombre 
illimite de criteres, reprenant done mot pour mot le concept de taxo- 
nomie que nous avons aborde au chapitre precedent. 

Les taxonomies sont appelees « vocabulaires » et les termes (ou taxons) 
qu ils contiennent peuvent etre hierarchises les uns avec les autres. Un 
vocabulaire peut etre rendu obligatoire pour une serie definie de types de 
contenus. 

Drupal permet egalement Tetiquetage libre (ou free tagging) qui consiste 
a associer une serie de mots-cles, sans contrainte, a un contenu. 

Cette capacite de categorisation de contenu est ensuite utilisable pour les 
recherches, l’affichage par section, le croisement des criteres, ou encore 
par des modules tiers, comme pour l’affichage de nuages d’etiquettes. 
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Internationalisation 


Comme beaucoup de projets libres, Drupal est un produit developpe 
depuis pres de huit ans par des developpeurs venant des quatre coins de 
la planete. C’est done sans surprise que Ton disposera d un produit pou- 
vant s’afficher, selon les choix du visiteur ou les reglages de son naviga- 
teur, en plus de trente langues differentes, y compris asiatiques et arabes. 

Mais l’aspect international de Drupal ne s’arrete pas a lmterface : il integre 
en standard la capacite de gerer un meme contenu en autant de langues que 
desire, avec un systeme collaboratif de traduction des contenus. 

Gestion des droits 

Comme pour la taxonomie, la gestion des droits Drupal est poussee tres 
loin pour obtenir un niveau de controle que Ton a davantage l’habitude 
de voir sur un systeme d’exploitation. 

En effet, la ou d’autres CMS se contentent d’une vision administrateurs/ 
abonnes rendant delicat l’octroi de droits particuliers a certains abonnes, 
Drupal adopte la classique vue permissions/roles/utilisateurs. II est ainsi 
possible de maniere tres simple de donner a un utilisateur le droit de cor- 
riger des contenus sans lui permettre d’en creer, ou encore de moderer 
des commentaires sans quil lui soit possible d’aller plus loin. 

L’inconvenient (tout relatif) de cette approche est qu avec Drupal, la 
gestion des droits est une tache a part entiere qui doit etre pensee au 
moment de la conception du site. 

Ouverture aux bases de donnees 

Beaucoup de CMS, surtout en PHP, se limitent a la simple prise en 
charge de la base de donnees MySQL. Sur cet aspect, Drupal adopte un 
positionnement agreablement agnostique (meme si pour Tinstant, seules 
deux bases de donnees sont effectivement prises en charge). Les modules 
se reposent en effet sur une batterie de fonctions qui leur cachent com- 
pletement la nature de la base de donnees sous-jacente, y compris le 
point delicat de la creation des tables. 

En resulte un CMS qui peut fonctionner nativement aussi bien sous 
MySQL que sous PostgreSQL. Nous ne parlons la que de la prise en 
charge par defaut, d’autres projets s’occupant par exemple de la base de 
donnees Oracle (http://archimedes.bitfine.com/dms/oradrup) ou encore Microsoft 
SQL Server. 
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Performances 


Pour doper ses performances, Drupal utilise un systeme de cache tres 
avance. Pour ceux qui decouvrent cette technique, un cache nest rien 
d’autre quune zone dans laquelle Drupal va Stocker une page, un bloc ou 
un contenu precalcule pour ne faire les traitements quune seule fois. 
Nativement, Drupal stocke son cache dans la base de donnees, mais 
comme toujours, cet aspect est modifiable par des modules pour per- 
mettre du cache en memoire (extremement rapide) ou encore sur le sys- 
teme de fichiers. 

Ceci dit, se reposer totalement sur ce systeme de cache pour garantir les 
performances d un site a forte charge nest pas forcement tres sage. En 
effet, Drupal ne sait pour fheure que mettre en cache les pages des visi- 
teurs anonymes. Des que lutilisateur est identifie, une partie de ce systeme 
de cache est desactivee, ce qui implique une baisse des performances. 

Ce probleme ne touchera que peu de monde, car rares sont les sites dont la 
majorite de visiteurs est identifiee. Mais il faut malgre tout garder a lesprit 
ce travers dans les performances de Drupal lors de la conception de son site, 
en evitant par exemple de le surcharger de modules inutiles. 

Dimensionnabilite 

S’agissant de sites a fort trafic, la capacite a monter en charge ( scalability ) 
devient un point crucial. Pour rappel, nous parlons ici de la possibility 
d’augmenter facilement fenvergure du site (nombre d’utilisateurs, trafic, 
nombre de contenus, etc.) sans pour autant perdre en performances. Cette 
augmentation peut etre ponctuelle (pic de charge) ou structurelle (succes 
du site, extension d un departement pilote a l’entreprise en general, etc.). 

Dans ce dernier cas, la dimensionnabilite d un outil se traduit generale- 
ment par sa capacite a fonctionner sur plusieurs machines, ce qui dans 
notre cas est plus le probleme de la base de donnees que du CMS en lui- 
meme. Malgre tout, Drupal apporte la aussi une flexibility supplemen- 
taire en acceptant rutilisation de PostgreSQL qui se revele beaucoup 
plus lineaire dans sa montee en charge que MySQL. Enfin, Drupal 7 
ameliorera la prise en charge des architectures redondantes, deja pre- 
sente partiellement dans Drupal 6. 

Pour ce qui est d’absorber une charge ponctuelle, Drupal exploite son 
architecture modulaire par un mecanisme de balance de charge. II sera 
ainsi possible de parametrer certains modules et meme certains contenus 
(les blocs) pour se desactiver automatiquement en cas de pics de trafic. Le 
site fonctionnera ainsi en mode « degrade » mais sans rupture de service. 
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La licence GPL v2 de Drupal 

Drupal est un logiciel libre, et c’est cette liberte qui rend possible le tra- 
vail d’une communaute entiere de developpeurs, de traducteurs, 
d’auteurs d’articles et de documentation, produisant jour apres jour un 
outil encore meilleur. 

Ses sources, comme celles de l’ensemble des modules, sont disponibles 
sous Licence GPLv2. Vous avez done le droit de copier le code sans 
payer de royalties, de mettre en place Drupal oil vous le desirez, et de 
modifier le code qu’il contient comme bon vous semble. 

En echange de cette liberte qui ne vous coute rien, votre seule obligation 
consiste a rendre public le code que vous aurez modifie. Ainsi, si vous ame- 
liorez un module pour votre site, vous devez absolument proposer ces modi- 
fications a la communaute. Libre a elle, ensuite, de les accepter ou non. 

Ce type de licence a fait naitre une legende entretenue par nombre de 
personnes plus ou moins bien intentionnees qui voient d un mauvais oeil 
que Ton puisse mettre a disposition des ressources de qualite, alors 
qu’eux gagnent leur vie en faisant la meme chose. Cette legende pretend 
qu’utiliser un logiciel libre comme Drupal vous obligerait a fournir a la 
communaute tout le code source de votre site. C’est absolument faux. 

En effet, il y a une difference entre modifier une source existante et creer 
son propre code. Si pour votre site, vous fabriquez des themes et des 
modules, rien ne vous oblige a les placer sous licence GPL. Ce serait evi- 
demment fortement apprecie, mais c’est votre droit de ne pas le faire. 

Avec le libre, vous avez done le choix au sens large du terme. 


Culture Libre et gratuit, la difference 

La confusion entre « libre » et « gratuit » qu'entre- 
tiennent souvent journaux et medias merite d'etre 
levee, le lecteur de PDF fourni par Adobe est tota- 
lement gratuit, certainement pas libre. Vous ne 
pouvez en avoir le code source pour I'auditer par 
exemple, vous ne pouvez pas le traduire, ni en 
faire votre propre version et meme son utilisation 
est soumise a conditions (conditions en general 
acceptees negligemment lors de I'installation). Un 
logiciel libre est I'inverse de tout cela. Vous dis- 
posez des sources, vous pouvez les lire, les modi- 
fier, les publier sous une autre forme. Et tout cela, 
plus que gratuitement : sans restriction aucune. 


En resume 

• Drupal est un outil libre sous licence GPLv2, de meme que 
l’ensemble des modules que nous utiliserons dans cet ouvrage. 

• L’ architecture de Drupal est modulaire et peut etre etendue dans 
toutes les directions imaginables. 

• Drupal implemente la quasi-totalite des concepts d’un CMS. 

• De par sa nature complexe, il est important de garder en tete l’aspect 
performance qui peut devenir le point faible d’un site Drupal. 
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Bien definir son projet 


Quel que soit l’usage que vous reservez a Drupal, il faut se 
poser plusieurs questions avant de commencer le moindre 
travail. Car s’il est possible de faire tout ou presque avec 
Drupal, il est aussi possible de faire a peu pres n importe quoi. 
Mai definir le besoin, mais aussi le contexte technique du 
projet, c’est prendre le risque d’obtenir un site trop lent, non 
integre avec l’environnement ou pire encore, purement et 
simplement rejete par les internautes. 


SOMMAIRE 

► Definir I'objectif de son site 

► Les bons reflexes pour 
formaliser ses idees 

► Les etapes pour definir 
les fonctionnalites 

► Penser aux contraintes 
techniques 
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Quel est votre objectif ? 

Formaliser l’objectif de notre projet en quelques phrases simples permet 
d’avancer en ayant les idees claires, mais egalement de faire comprendre 
a d’autres ce que nous cherchons a realiser. Aucun projet ne se reussit 
seul dans son coin, aussi n’hesitez jamais a en discuter avec vos collegues 
ou vos proches. 

Dans ce livre, nous chercherons a realiser le site web de la societe (Ac- 
tive) de conseil en management Colchique, dont l’objectif sera : « La 
presentation des domaines d’activite de la societe et de ses references les 
plus prestigieuses. II devra aussi permettre la publication d’articles tech- 
niques traitant de divers sujets lies a son coeur de metier. Le site propo- 
sera en outre une serie de services transversaux comme l’abonnement a 
des lettres d ’informations permettant a la societe de communiquer sur 
son actualite et celle de son domaine. » 
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De I’objectif au storyboard 

Avant de poursuivre, il convient de faire la distinction entre deux con- 
cepts, l’ergonomie d’un site, et sont apparence. 

L’ergonomie consiste a etudier la meilleure maniere d’architecturer les 
pages de votre site pour correspondre parfaitement aux usages et aux 
besoins de vos visiteurs. II s’agit principalement de determiner ici la 
maniere de naviguer, la disposition des contenus et des liens, les ele- 
ments mis en avant ou en arriere-plan, etc. 

Ce processus se fait en gardant a l’esprit le public envisage. Comment 
s’attend-il a trouver l’information ? Comment voudrait-il que le contenu 
soit organise ? Quelles sont ses habitudes de travail, quelles choses sou- 
haiterait-il trouver au premier regard ? Etc. 

L’ apparence de notre site correspond a l’image et a l’impression que vous 
cherchez a produire : choix de la palette de couleurs, du type de gra- 
pheme, etc. Lorsqu’il s’agit d’un site d’entreprise, nous pourrons nous 
appuyer sur sa charte graphique. 

De maniere generale, il convient deja de separer, ici aussi, le fond et la 
forme. L’ergonomie choisie pour un site a, certes, des incidences sur les 
couleurs ou les graphismes, mais il s’agit surtout de determiner la 
maniere dont il va etre organise, ce que contient chaque grande section, 
et la navigation qui va lier l’ensemble. 

L’ergonomie en general est un bien vaste sujet, meme reduit au seul 
domaine des interfaces humain-machine, et plus precisement aux applica- 
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tions web. C’est sans doute pour cela quil existe un metier d ergonome a 
part entiere. Si vous realisez un site professional, il sera inevitable de faire 
appel a un tel specialiste, ou plus generalement a un graphiste ayant de 
solides connaissances sur votre type de metier et sur l’ergonomie du Web. 

Si vous etes a 1’aise avec ces notions ou que le site que vous comptez rea- 
liser est suffisamment simple, vous pouvez faire ce travail vous-meme. 
Dans tous les cas, le passage difficilement contournable reste la redac- 
tion d un storyboard. 


Reference Ergonomie web 

£Q A. Boucher, Ergonomie Web - Pour des 
sites web efficaces, 2 e edition, Eyrolles, 


Mettre en place le scenario (storyboard) 

Un storyboard est un mot emprunte au vocabulaire cinematographique. II 
s’agit de la representation illustree d un film avant sa realisation dans le but 
de planifier les plans principaux et leurs enchainements. Pour un site web, 
le principe du storyboard est le meme, a la difference que les plans seront 
plutot les differentes sections, rubriques et autres pages specifiques. 

II n existe pas reellement de methode stricte pour creer son storyboard. II 
doit juste faire ressortir clairement les differentes sections du site et les 
enchainements entre ses sections. Cela peut etre fait de maniere tres 
simple par un organigramme fonctionnel. 
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Figure 3-1 Organigramme fonctionnel de notre site 
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Rien ne sert ici d’aller dans le detail des liens. II s’agit de la navigation gene- 
rale. Dans le schema qui precede, il est important de bien montrer que : 

• le site a deux facettes, une partie institutionnelle ( Activites ) et une 
partie redactionnelle ( Publication ) ; 

• le site presente d’abord une page de garde (qui peut etre une anima- 
tion, a utiliser avec parcimonie, car cela peut incommoder le visiteur), 
puis une page d’accueil qui permettra d’aiguiller les visiteurs vers 
Tune des sections. 

Se plonger brievement dans les details 

II est possible et meme souhaitable d’aller encore plus loin dans le detail 
en decrivant precisement chacune des presentations types. L’exemple ci- 
dessous correspondrait a la presentation de la page d’accueil. 


Formulaire de contact 


Afficher si I'utilisateur est 
authentifie 


Nous contacter Se deconnecter 



Zone de 
™ recherche 





J Sur la page d'accueil 



Sur les autres pages 


Figure 3-2 Le storyboard de la page d'accueil de notre site 


Plus vous serez precis dans cette phase de conception, plus la suite se pas- 
sera simplement pour vous et pour les personnes avec qui vous travaillerez. 
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Quels sont vos types de contenu ? 

Une fois le storyboard termine, nous avons une vision plus claire des 
types de contenu qui nous seront necessaires, ainsi que des elements les 
constituant : 

• un contenu de type Reference : une fiche decrivant de maniere syn- 
thetique une realisation effectuee par la societe, avec les domaines de 
competences techniques mis en oeuvre pour cette realisation ; 

• un contenu de type Article : une publication ecrite par Tun des colla- 
borateurs et traitant d un sujet donne ; 

• un contenu de type Billet : comme un article, mais plus court. 

Pour nous assurer de l’exhaustivite de cette liste, nous pouvons la forma- 
liser de maniere plus graphique : 



Articles 


Title 


Auteur 


Date de creation 

■4 

Domaines de 


competence 

** 

Corps 



Billet 


Titre 

4 

Auteur 

4 

Date de creation 

4 

Domaines de 


competence 

-4 

Corps 



Reference 

-4 

Objet de la mission 

4 

Date de la mission 


Prestation realisee 

>4 

Resultats obtenus 


Domaine de 


competence 

*4 

Acteu rs 


Figure 3-3 

Les types de contenu a implementer 


Les roles de vos utilisateurs 

Le CMS est un outil collaboratif qui permet a tous les utilisateurs auto- 
rises de creer, modifier, detruire et publier (c’est-a-dire rendre public) 
des conte nus. 

A fexclusion du cas d un site personnel, la definition des roles, et done des 
permissions de chacun dans ce processus d’animation, est une etape aussi 
importante que generalement oubliee. II serait pourtant dommage que des 
informations confidentielles soient rendues publiques par accident... 

Comme nous favons deja vu, un role dans un CMS correspond a une 
liste de permissions pouvant etre attributes a un utilisateur. Du point de 
vue organisationnel, il s’agit de la fonction que prend un collaborates a 
un moment t donne pour effectuer une tache specifique. 

Pour le site de la societe Colchique, nous deciderons que tous les con- 
tenus de type Article (les publications) passeront par quatre etats avant 
leur publication : Brouillon, A corriger, Corrige et Valide. Cet ensemble 
d’etats forme les etapes de ce qui est appele un flux de travaux (en anglais 
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workflow). Chaque passage d’etape est assure par des utilisateurs ayant le 
role approprie : 

• Tauteur (aussi appele contributes), qui est la personne redigeant des 
contenus. C’est lui qui fera passer le contenu de l’etat Brouillon a A 
corriger ; 

• le correcteur, qui est la personne relisant et corrigeant les contenus 
dans l’etat A corriger, pour finalement les faire evoluer vers l’etat 
Corrige ; 

• le validateur, qui valide les contenus marques Corrige et decide de 
leur passage a l’etat Valide, condition necessaire a leur publication ; 

• le visiteur anonyme, qui consulte les contenus publies sur le site. 

Ainsi, un document publie sur le site et visible par tout public sur 
Tlnternet aura forcement suivi nos etapes de traitement, garantissant 
qu’il ne contient ni coquille, ni information sensible. 

Vous pouvez encore une fois decrire ces flux de travaux de maniere plus 
visuelle : 


Figure 3-4 

Le flux de travaux 




Auteur 


[Brou illon] 


Auteur 


(A corriger] 


[ Corrige [ 


Correcteur 




VaSidateur 


| Valide ] 


Prevoir vos contraintes techniques 


A ce stade, nous avons une vision claire des informations que nous mani- 
pulerons, et avons defini les roles et les types de contenu. II nous reste a 
penser aux contraintes que nous allons imposer a notre nouveau projet. 
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Le systeme ((’information 

Si votre objectif est de creer un site personnel, ceci vous touchera peu, 
mais si, comme dans notre exemple, vous oeuvrez pour une societe, il est 
important de prendre conscience que votre site web n est pas une lie 
isolee. II s’integre dans un ensemble plus vaste que Ton appelle commu- 
nement « le systeme d ’information » de la societe. II devra sans doute 
puiser des informations dans des bases de donnees externes a Drupal 
(par exemple les noms et mots de passe des collaborateurs). II pourra 
aussi avoir a s’interfacer avec d’autres systemes pour en retirer des don- 
nees ou en injecter (par exemple un systeme de paiement en ligne, un 
systeme de comptabilite, etc.). 

Tous ces elements doivent imperativement etre listes des a present pour 
eviter toute mauvaise surprise au moment de la mise en oeuvre. 


Le contexte technique 

Dans le meme style d’idees, vous devez penser a l’endroit ou le site sera 
heberge. Est-ce un serveur dedie ou une machine partagee avec d’autres 
applications ? Dans le second cas, la base de donnees vous sera sans 
doute imposee, ou encore le systeme d’exploitation. II est important de 
le savoir des le debut, pour ne pas demarrer le travail en utilisant des ele- 
ments incompatibles avec l’infrastructure finale. Un exemple classique 
est de construire puis tester votre site sur une base de donnees (par 
exemple MySQL), pour decouvrir que la seule machine que l’on vous 
propose pour l’hebergement utilise PostgreSQL. Ce n’est pas drama- 
tique, mais cela vous obligerait a retester tout votre site pour vous assurer 
de sa bonne compatibility. 


Votre public et la frequentation escomptee 

Le dernier aspect a evaluer est la frequentation que nous attendons sur ce 
site. En effet, un site qui re^oit une centaine d’utilisateurs par jour n’aura 
pas les memes contraintes qu’un autre qui en recevra autant... par 
seconde. La maniere de construire le site ne sera pas exactement la 
meme dans l’un ou l’autre cas. Vous devez done estimer aussi precise- 
ment que possible la volumetrie. Dans ce calcul, pensez a separer la volu- 
metrie des utilisateurs anonymes de celle des utilisateurs authentifies. 
Drupal ne les gere, en effet, pas de la meme maniere, et si votre site est 
majoritairement utilise par des utilisateurs connus du systeme, certaines 
options seront plus pertinentes que d’autres. 


Bon A SAVOIR Les resolutions 

Les resolutions d'ecran a prendre en compte lors 
de la conception d'un site web sont a nuancer en 
fonction du panel envisage de vos utilisateurs. En 
effet, un public fortement technophile sera sans 
nul doute mieux equipe qu'un public plus large. 
Notez qu'en juin 2009 (source LibStat), les resolu- 
tions les plus utilisees sont : 

• 1024 X 768 (33 %); 

• 1280 X 800 (16 %); 

• 1 280 X 1024 (12,58 %); 

• 1400 X 900 (11,5 %). 
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Bon A SAVOIR Les navigateurs et les moteurs de rendu 

II n'est pas forcement evident de s'y retrouver dans la jungle des navigateurs, sauf si Ton rai- 
sonne a partir de leur moteur de rendu. En effet, chaque navigateur utilise une bibliotheque 
particuliere, qui a pour role de transformer le code HTML/CSS en une representation visuelle. 
Cette bibliotheque s'appelle un moteur de rendu. 

II existe beaucoup moins de moteurs de rendu que de navigateurs, ou en d'autres termes, plu- 
sieurs navigateurs utilisent le meme moteur de rendu : 

• Gecko est le moteur de rendu d'un tres grand nombre de navigateurs : Netscape, Firefox, 
Iceweasel, Camino (Mac OS), Flock, Epiphany et Galeo (Gnome), etc. ; 

• Trident est le moteur de Microsoft, utilise dans les navigateurs Internet Explorer (a partir 
de la version 4), MylE (aka Maxthon), Avant Browser ou encore AOL Explorer ; 

• WebKit (issu du moteur KHTML) est utilise dans les navigateurs Epiphany et Midori 
(Gnome), Google Chrome, Konqueror, OmniWeb, Dafari, Shiira, etc. ; 

• Presto est le moteur d'Opera. 

Sachant cela, vous pouvez specifier comme contrainte technique le moteur de rendu et ainsi 
vous assurer (dans une certaine mesure) de la compatibility avec les navigateurs qui I'utili- 
sent. 

En juin 2009 (source Libstat), les navigateurs les plus utilises sont : 

• Microsoft Internet Explorer 7 (37,96 %) ; 

• Firefox 3 (24,4 %) ; 

• Microsoft Internet Explorer 6 (1 6,86 %). 
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En resume 

• L’etape de definition d’un projet nest pas seulement utile, elle est 
indispensable pour realiser un travail propre et dans les delais fixes. 

• Le site que vous concevez n est pas la pour repondre a vos besoins, 
mais a ceux de vos visiteurs et utilisateurs. 

• La conception d un site passe par la definition des acteurs (roles), des 
fonctionnalites attendues et de leur organisation (navigation). 

• Faites le tri entre les fonctions fondamentales (ex. creer un article) et 
les fonctions transversales et utilitaires (ex. generer un PDF). 

• N’omettez jamais de definir precisement la plate-forme technique 
cible et la frequentation attendue. 
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Colchique 



administrates 

Bienvenue sur votre nouveau site Drupal ! 

Mon compte 

Merci de suivre ces etapes pour configurer et com me ncer a I'utiliser : 

Creer uncontenu 


; Administer 

1 . Configurez votre site web 

Se deconnecter 

Unefois connecte, visitez la section d 'admin istration.ou vous pouvez perso 


2 . Ac t iv e z des f one tio rts s upple m e nl a ires 

Em suite, visitez la listecTes modules et aclivez les tone tio nnalites qui convie 
modules dans la section- de te lech ange merit de modules de Drupal, 


3. Personrralesez I'apparence de votre site web 

Pour changer I'apparence et leoomportementde voire site web, visitez !a se 
ou Is lech anger d'autnec the me c dans la cecitcm de te tec h angeme nt dec them 

4. Commencez a contribuer 

Enlin, vous pouvez crier du conienu pour votre site web. Ge message disp; 
d'accueil. 


www.frenchpdf.com 


Mettre en place son 
environnement de 
developpement 


Comme n importe quel projet informatique, un site web 
necessite la mise en place d un environnement 
de developpement sur une machine de travail. Plus cette 
plate-forme sera propre et efficace, moins vous serez tente 
de travailler directement sur le serveur de production. 

En prenant l’habitude de travailler et de tester sur cet 
environnement dedie, vous contribuerez ainsi a augmenter 
la robustesse de votre site. 


SOMMAIRE 

► Apache et PHP, les moteurs 
de Drupal 

► Mettre en place un 
environnement WAMP et LAMP 

► Creer votre base de donnees 

► Resoudre les difficulty 
techniques 
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Les technologies mises en oeuvre 


Le service HTTP 


Un site web fonctionne peu ou prou toujours de la meme maniere. Le 
navigateur web (Firefox, Safari, Opera, Internet Explorer, etc.) se con- 
necte a un service HTTP en lui fournissant une requete portant sur une 
URL donnee (ex. http://mon_site.com/ma_page.html). Le service HTTP va 
alors chercher sTl existe un fichier nomme ma_page . html , et si c’est le cas, 
le renvoyer au navigateur qui va simplement en afficher le contenu. 

Si le fichier HTML contenait le code suivant : 


<HTML> 

<B0DY> 


Bon jour ! 

</B0DY> 

</HTML> 

Le navigateur afficherait alors le texte « Bonjour ! » en noir sur fond blanc. 

Jargon Serveur et service 

Le mot serveur est un element du jargon designant la machine qui va 
repondre a une requete par le biais d'un logiciel, le service. Ce vocabu- 
laire est tire de la vie reelle ou nous avons le gargon de cafe (le serveur) 
qui va prendre notre commande (la requete) et nous apporter un 
expresso (le service). 

Le probleme est que le mot « serveur » est tres souvent utilise dans deux 
contextes qui n # ont pourtant rien a voir. Parfois il designe un service, 
c'est-a-dire un logiciel (ex. service HTTP, serveur SMTP) qui est installe 
parmi d f autres services sur une meme machine. Parfois il designe la 
machine elle-meme (ex. le serveur de mise en production). La raison de 
cette confusion est que dans beaucoup de cas, un serveur (la machine, 
cette fois) est utilise pour un et un seul service (ex. serveur de messa- 
gerie). Mais dans la realite, il est tout aussi reducteur d f assimiler un ser- 
veur a un service, que de reduire le gar^on de cafe a la seule capacite de 
servir des expressos. 

Dans la mesure du possible, pour eviter toute confusion, nous essaye- 
rons dans ce livre d'utiliser plutot le mot « service » lorsqu'il s'agira du 
logiciel et « serveur » pour la machine. 

Si la page contient un lien hypertexte et que l’utilisateur clique dessus, le 
navigateur fera a nouveau une requete au service HTTP portant sur 
FURL du lien, et recuperera une nouvelle page. Et ainsi de suite. 
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Le service HTTP est done le logiciel qui va repondre a une requete du "I 

navigateur web. II existe de nombreux services HTTP differents : 

LightHTTP, Apache ou encore IIS. Drupal ayant ete concpi pour etre le 
plus souple possible, il est techniquement possible de le faire tourner sur 
la majorite d’entre eux. Cependant, Apache reste le service HTTP de 
loin le plus populaire. (Test done lui que nous utiliserons pour construire 
notre plate-forme de developpement. 


Le langage PHP 

PHP (pour Hypertext PreProcessor) est un langage de programmation spe- 
cialement con^u pour realiser des applications web. La difference entre 
application web et site web vient cette fois du fait que le contenu des pages 
nest plus statique, mais construit dynamiquement a chaque requete. 
Lobjectif de PHP est ici de modifier le contenu HTML en lui ajoutant 
des instructions speciales. Si nous voulions ajouter F affichage de Fheure a 
notre exemple precedent, nous ajouterions le code PHP suivant : 

<HTML> 

<BODY> 

Bonjour, il est <?php print date() ?> ! 

</BODY> 

</HTML> 


HlSTOlRE Personal Home Page 
ou Hypertext Preprocessor ? 

Lorsqu'en 1995, Rasmus Lerdorf libera le code 
source de PHP, I'acronyme signifiait Personal 
Home Page. En 1997, Andi Gutmans et Zeev 
Suraski redevelopperent completement PHP pour 
donner naissance un an plus tard a Zend Engine, la 
version 3 du coeur de PHP, qui signifiait cette fois 
Hypertext Preprocessor. 


Comme vous le voyez, Finclusion destructions PHP dans du code 
HTML est aussi simple que directe. C’est d’ailleurs cette caracteristique 
qui en a fait le langage le plus utilise au monde. 

Drupal etant ecrit en PHP, ce dernier lui est absolument necessaire. La 
version 4 de PHP suffit pour travailler avec Drupal jusqu’a sa version 6 ; 
en revanche, PHP 5 sera necessaire a Drupal 7. Il est done conseille 
d utiliser des maintenant PHP 5. 


La base de donnees 

Drupal utilise done PHP pour construire ses pages « a la volee », mais il 
ne serait rien sTl n avait pas une base de donnees pour le seconder. En 
effet, toute la configuration du site, le theme utilise, la position des ele- 
ments dans la page, et bien evidemment, les contenus eux-memes sont 
autant d’informations stockees dans cette base. 

Nous Favons vu, un des points forts de Drupal est sa souplesse vis-a-vis 
des bases de donnees. Techniquement, Drupal 6 pourrait tourner avec 
nimporte laquelle d’entre elles, sous reserve que le greffon correspon- 
dant existe. Dans les faits, les deux bases de donnees les plus utilisees 
avec ce CMS sont MySQL et PostgreSQL. Le choix de Fune ou Fautre 
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de ces deux bases vous appartient done. Concernant MySQL, sachez 
seulement que Drupal ne fonctionnera pas en dessous de la version 4.1. 


B.A.-BA Les bases de donnees 

Une base de donnees est un logiciel dont le but est de Stocker et de 
manipuler des donnees. On parle aussi tres souvent de SGBD pour Sys- 
teme de gestion de bases de donnees. 

Dans une base de donnees dite relationnelle (ou SGBD-R), les informa- 
tions sont stockees dans des tables, composees de colonnes appelees 
champs , et de lignes contenant les valeurs de ces champs. Chaque ligne 
est appelee enregistrement ou tuple. L'aspect relationnel tient a ce que 
les tables sont generalement reliees entre elles. Par exemple, une table 
« clients » a une relation avec une table « societes » # qui est « la societe 
a laquelle appartient le client ». 

A une certaine epoque, les SGBD-R etaient totalement autonomes et 
contenaient des applications completes. Aujourd'hui, dans la plupart 
des cas, elles constituent avant tout I'espace de stockage utilise par des 
applications plus evoluees comme Drupal. 

Pour discuter avec un SGBD-R, humains et applications utilisent le meme 
langage, le SQL. Ce langage est utilise sous la forme de requetes a la 
base de donnees pour creer de nouvelles tables (CREATE TABLE), inserer 
des enregistrements (INSERT), les mettre a jour (UPDATE) et faire des 
recherches (SELECT). 

II existe de tres nombreux SGBD-R (Oracle, Sybase, Microsoft SQL Server, 
etc.) dont certains sont des logiciels libres (MySQL, PostgreSQL, 
BerkleyDB, etc.). 


Culture Qu'est ce que LAMP ? 

LAMP est un acronyme trouve par Michael Kunze 
dans le magazine Allemand Computertechnik 
(C't). L'objectif de Particle etait de prouver qu'un 
assemblage de logiciels libres (en I'occurrence 
Linux, Apache, MySQL et PHP) pouvait sans pro- 
bleme concurrencer les offres commerciales pre- 
sentes alors sur le marche. 

Le principe de I'environnement LAMP a plus tard 
ete decline en WAMP (Windows Apache MySQL 
PHP), puis MAMP (MacOS Apache MySQL PHP), 
puis avec la democratisation de I'excellente base 
de donnees PostgreSQL, sont arrives les architec- 
tures LAPP (Linux Apache PostgreSQL PHP). 


Le systeme Sexploitation 

Dans ce domaine, vous etes absolument libre. Les trois briques que nous 
venons de decrire fonctionnent aussi bien sous GNU/Linux que sous 
Solaris, Mac OS ou encore Windows. II est done possible de combiner 
tout cela sans probleme et de monter une plate-forme WAMP (Win- 
dows Apache MySQL PHP), MAMP (MacOS Apache MySQL 
PHP), LAPP (Linux Apache PostgreSQL PHP), etc. 

Pour la majorite de systemes d’exploitation, il existe de nombreux 
paquets prets a l’emploi qui installent l’ensemble (Apache, MySQL, 
PHP, etc.) en une seule passe. 

Puisquil faut faire des choix, nous allons decrire ici finstallation de deux 
types de plates-formes : une WAMP et une LAMP. 
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Creation d’un environnement WAMP 


Installation de WampServer 

Pour installer Apache, PHP et MySQL sous Windows, nous allons 
choisir, quelque peu arbitrairement, le paquet WampServer 
(http://www.wampserver.com), mais il y en a beaucoup d’autres qui fonction- 
nent tous a peu pres sur le meme principe. 

Pour commencer, vous devez telecharger le paquet a installer a Tadresse 
http://www.wampserver.com/download.php. Nous utilisons ici la version 2.0. En 
cliquant sur le lien de telechargement, vous etes detourne sur le site 
sourceforge.net qui heberge les binaires du projet. 


source 


FIND AMD DEVELOP OPEN-SOURCE SOFTWARE 


Find' Software Develop Community Site Support About 


Your WampServer download will start shortly. . . 



Figure 4-1 

Telechargement de I'archive de WampServer 2.0 
a partir des serveurs de sourceforge 


Une fois le fichier WampServer2.0h.exe recupere, vous pouvez double- 
cliquer dessus pour l’installer. 



Figure 4-2 

Choix du service SMTP 
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Jargon Service SMTP 

SMTP veut dire Simple Mail Transfer Protocol 
(litteralement, protocole simple de transfert de 
courrier). II s'agit du mode de communication 
standard utilise par deux machines pour s'envoyer 
du courrier. 

Lorsque vous diquez sur le bouton Envoy er de 
votre client de messagerie, ce dernier utilise la plu- 
part du temps ce protocole pour transferer votre 
message au service SMTP de votre fournisseur 
d'acces a Internet (FAI). Une fois que ce dernier a 
regu un message, il va a son tour contacter le service 
SMTP de votre correspondant (le champ a de votre 
message) pour lui remettre a son tour le courrier. 
Dans notre cas, le service SMTP a une grande 
importance, car c'est lui qui recevra tous les cour- 
riels de confirmation, notifications et autres mes- 
sages d'information qui vont etre envoyes par 
Drupal tout au long de notre exploration. 


Figure 4-3 

Le menu de WampServer 


WWW 


Au cours du processus d ’installation vous seront demandes les elements 
suivants : 

• le dossier d’installation : laissez les valeurs par defaut c : \wamp ; 

• si vous voulez utiliser la page de garde de WampServer, repondez 
oui ; 

• PHP Mail parameters : dans le champ SMTP, fournissez l’adresse du 
service SMTP qui vous a ete communiquee par votre fournisseur 
d’acces a l’lnternet (FAI, voir figure page precedente). Dans le 
champ E-mail, vous pouvez indiquer votre adresse de courriel qui sera 
utilisee par defaut dans le champ de des messages envoyes. 

Une fois installe, WampServer propose de lancer l’ensemble de ses ser- 
vices (MySQL et Apache) directement, ce que nous acceptons. 


Test de la plate-forme 

Si tout s’est bien passe, nous devrions voir apparaitre une nouvelle icone dans 
la boite a miniatures (sur la droite de la barre de taches, a cote de l’heure). 



Vous disposez en has de ce menu des options d’arret des services Apache 
et MySQL ( Stop All Services), de lancement (Start All Services) et de rede- 
marrage (Restart All Services). 

Nous commencerons done par demarrer ces services et verifier leur bon 
fonctionnement en tapant http://localhost dans la barre d’adresse de notre 
navigateur. La page de garde de WampServer devrait alors apparaitre. 

Dans ce paquet, vous avez aussi acces a phpMyAdmin, un outil simplifie 
d’administration de la base de donnees MySQL, a l’adresse http://localhost/ 
phpmyadmin. 

Comme la page de phpMyAdmin s’affiche correctement, nous pouvons 
en deduire que la base de donnees MySQL est operationnelle. Notez au 
passage que par defaut, le service MySQL de PhpMyAdmin est confi- 
gure sans mot de passe. II n’est done pas necessaire de s’authentifier pour 
s’y connecter, comme ce sera le cas pour notre installation LAMP. 
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Figure 4-4 

La page de demarrage de WampServeur : 
tout fonctionne... 



Figure 4-5 

L'outil indispensable a MySQL, phpMyAdmin 
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C:\warnp\www j 

Fichier Edition Affichage Favoris 

i,^j) Pretederite - t ^ 



Adresse [3 C:\wamp\www 


index, php 
Fichier PHP 
37 Ko 


Figure 4-6 

La page par defaut de WampServer 



Reperer les fichiers source 

Plus prosaiquement, la page de garde disponible a l’adresse http://localhost 
est un fichier i ndex . php stocke en local dans le dossier c : \wamp\www. Vous 
pouvez y acceder directement par le menu WampServer www directory. 

Tous les fichiers qui seront poses a cet endroit seront done accessibles 
par le biais du navigateur web. Nous pouvons en faire fexperience en 
ajoutant ici un fichier test. php. Ce fichier peut etre cree avec Notepad 
et contenir par exemple le code PHP suivant : 

<html> 

<head> 

<ti tl e>Bonjour le monde ! </ti tl e> 

</head> 

<body> 

<?php 

print "Bonjour, il est " .date("H :m: s") ; 

?> 

</body> 

</html> 

Une fois notre page de test sauvegardee, nous pouvons la tester en saisis- 
sant fadresse http://localhost/test.php dans le navigateur. Nous obtenons alors 
la page de statut du moteur PHP. 


Figure 4-7 

WampServer fonctionne done bien. 


Adresse Ci'/.vampVA'w 


3 


^ test, php 


Rchh 
1 Ko 


C' tesLphp- Btoc-notes 


index, php 


Fichier Edition Format Affichage ? 


<h£ad> 

ititl e>Bonjour le monde [ </tjtle> 
</head> 


<body: 

<?php 

print "Bor 

?> 

</body> 
</htnil > 


') Bonjour le monde! - Mozllla Flrefox 


Fichier Edition Affichage Historique Marque -pages Outils 7 
0” - e tii r^n http : /i'localhost/test. php 

Bonjour, il est 12:03:35 


Creation d’un environnement LAMP 

Considerations sur les distributions 

Dans la suite de ce paragraphe, nous partons du principe que vous etes 
deja familiarise avec le systeme d’exploitation Linux et plus particuliere- 
ment avec la notion de paquets d ’installation. 

Pour ce qui est de la distribution, nous utilisons dans cet exemple 
Mandriva, mais la transposition a une autre distribution est assez directe, 
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les noms des paquets etant toujours plus ou moins les memes. Seules les 
commandes utilisees pour les installer different. 

Ici nous allons utiliser uniquement la ligne de commande au risque 
d’entretenir le mythe d’un Linux peu ergonomique. En realite, toutes les 
distributions permettent aujourd’hui de faire ce travail aide d’une inter- 
face graphique. Malgre tout, fapproche en ligne de commande reste de 
loin la plus facile a transposer d une distribution a l’autre. 


Installation d’Apache 

La premiere etape de Installation se fait a partir d’une console ouverte 
sur l’utilisateur root. Ceci est necessaire pour avoir le droit d ’installer des 
paquets et de modifier les configurations. 

Nous commen9ons par le service Apache, dont il existe plusieurs 
variantes qui different surtout par la maniere de gerer les acces concur- 
rents. Pour PHP, il est conseille d’utiliser la variante mpm- prefork. 

root# urpmi apache-mpm-prefork 


Bon A savoir Task-lamp 

Sous Mandriva, nous disposons aussi d'un meta- 
paquet nomme task-lamp, qui comme son nom 
I'indique, provoque ('installation directe de tout 
I'environnement LAMP. 


root# /etc/i ni t . d/httpd start 
Starting http: [ OK ] 

Nous pouvons valider cette etape a l’aide d’un navigateur web en allant a 
l’adresse http://localhost : 


Repondez par oui a toutes les demandes d’installation qui vont suivre 
apres le lancement de cette commande, il s’agit des dependances neces- 
saires a la bonne marche d’Apache. 

Une fois le processus termine, nous pouvons demarrer le service 
HTTPD (Apache) de la maniere suivante : 



Figure 4-8 

Test du bon fonctionnement d'Apache 
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Reperer les fichiers source 

Par defaut, Apache va chercher ses donnees dans le dossier /var/www/html . 
S’agissant d une installation de developpement, nous allons nous approprier 
ce dossier pour pouvoir le manipuler dans l’avenir sans avoir a utiliser le 
compte root. Si nous partons du principe que lutilisateur sera Gaston, nous 
lui donnerons les droits sur le dossier de la maniere suivante : 

root# chown gaston : gaston /var/www -R 

A present, lutilisateur Gaston est le proprietaire officiel de ce dossier et 
Apache garde la possibility de le lire. 

Comme pour notre installation WAMP, nous pouvons rediger un petit 
test pour verifier que PHP fonctionne correctement. Cette fois, il n est 
plus necessaire d'etre root, Gaston peut ouvrir sa propre console pour 
effectuer cette tache : 

gaston$ cat > /var/www/html /test . php 
<html> 

<head> 

<ti tl e>Bon jour le monde ! </ti tl e> 

</head> 

<body> 

<?php 

print "Bonjour, il est " .date("H :m: s") ; 

?> 

</body> 

</html> 

CTRL + D 

gaston$ 

Maintenant que le fichier est cree, nous allons pouvoir fafficher en sai- 
sissant Y adresse http://localhost/test.php dans le navigateur : 


Figure 4-9 

Test du bon fonctionnement de PHP 
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Installation de MySQL 

L’installation de MySQL se passe de la meme maniere que pour Apache, 
en tant qu’utilisateur root : 

root# urpmi mysql 

Lanc^ons le service pour nous assurer que tout fonctionne : 

root# /etc/init .d/mysqld start 
Starting MySQL: [ OK ] 

Une fois MySQL demarre, nous pouvons utiliser une procedure pour 
configurer rapidement les mots de passe et la securite : 

root# mysql_secure_i nstal lation 

NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL 
SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY! 


In order to log into MySQL to secure it, we’ll need the current 
password for the root user. If you’ve just installed MySQL, and 
you haven’t set the root password yet, the password will be blank, 
so you should just press enter here. 

Enter current password for root (enter for none): 

OK, successfully used password, moving on... 

Setting the root password ensures that nobody can log into the MySQL 
root user without the proper authorisation. 

Set root password? [Y/n] 

A la premiere question, entrez y (oui) et saisissez votre mot de passe. 
Conservez soigneusement ce mot de passe, sinon vous ne pourrez plus 
vous connecter a votre base de donnees. 

Aux questions suivantes, repondez comme suit : 

remove anonymous users ? y 
disallow root login remotly ? y 
remove test database and access to it ? y 
reload privilege tables now ? y 

Pour valider la bonne marche de MySQL, nous utilisons le client en 
ligne de commande en prenant 1 utilisateur MySQL root et le mot de 
passe que nous venons de donner : 

root# mysql -u root -p 
mot de passe: secret 

Welcome to the MySQL monitor. Commands end with ; or \g. 

Your MySQL connection id is 14 
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Server version: 5.0.67 Mandriva Linux - MySQL Standard Edition 
(GPL) 

Type ’help;’ or ’\h’ for help. Type *\c* to clear the buffer. 

mysql> show databases ; 

+ + 

| Database | 

+ + 

| i nformation_schema | 

I mysql | 

I test | 

+ + 

3 rows in set (0.00 sec) 

mysql>qui t 
root# 

Installation de phpMyAdmin 

Le client en ligne de commande est tres utile, mais il est appreciable de 
disposer comme sous Windows de phpMyAdmin. Pour cela, il nous 
suffit d ’installer le paquet correspondant : 

root# urpmi phpmyadmin 

Le service MySQL a redemarre automatiquement et il ne reste plus qu’a 
tester cela dans le navigateur a l’adresse http://localhost/phpmyadmin. 


phpMyAdmin 

Bien venue a phpMy Admin 

-Langue - Language 

Frant;ais - French A 


Figure 4-10 

La page d'authentification de phpMyAdmin 


r Connexion 

Utilisateur : 

Mot de passe : 


Nous disposons a present de l’environnement complet pour installer 
Drupal. 


48 


www.frenchpdf.com 



Telechargement de Drupal 

Nous avons maintenant, sous Windows ou sous Linux, une plate-forme 
de developpement operationnelle a laquelle ne manque que Drupal. A 
partir de maintenant, que vous soyez sous GNU/Linux, Mac OS ou 
Windows, nous n aurons plus besoin que dun simple navigateur. 

Site de telechargement 

Pour telecharger la derniere version de Drupal, il suffit d’aller sur la page 
d’accueil du projet Drupal a l’adresse http://drupal.org. Toutes les ressources 
telechargeables sont disponibles en cliquant sur l’onglet Download. 

Sur cette page se trouvent tous les types de ressources disponibles : 

• Drupal project : les sources de Drupal ; 

• Installation profiles : les profils d ’installation specialises pour certaines 
taches particulieres ; 

• Modules : tous les modules que l’on peut ajouter a Drupal ; 

• Themes : les themes libres que nous pourrons utiliser pour changer 
l’apparence de Drupal ; 

• Theme engines : ce sont des moteurs de theme qui pourront eventuel- 
lement etre utilises dans de rares cas ou le moteur standard ne con- 
viendrait pas ; 

• Translations : les traductions de Drupal en diverses langues. 

Pour l’instant, le type de ressource qui nous interesse est Drupal project. 

Pr oject types 

• Drupal project 

Get started by downloading the official Drupal core files. These 
official releases come bundled with a variety of modules and themes 
to give you a good starting point to help build your site. Drupal core 
includes basic community features like blogging, forums, and contact 
forms, and can be easily extended by downloading other contributed 
modules and themes. 


Une fois que vous avez clique sur ce lien, la liste des versions courantes 
de Drupal apparait. En vert, nous avons les versions stables et en rouge 
les versions en cours de developpement. 

Nous allons ici choisir la ligne verte (stable) de la version la plus recente 
de Drupal (6.10). Une fois la ligne reperee, cliquez sur le lien Download 
correspondant. 


Figure 4-11 

La section de telechargement du projet Drupal 


Attention 

Les versions instables des modules 

Sauf si vous desirez tester des versions experi- 
mentales de Drupal, il est fortement conseille de 
ne prendre que des versions stables. 
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Figure 4-12 

Les deux versions de Drupal 


Releases 


Official releases 

Date 

Size 

Links 

Status 


6.10 

2009-Feb-26 

1.03 

MB 

Download ■ 
Release notes 

Recommended 
for 6.x 


5.16 

2009-Feb-26 

748.29 

KB 

Download ' 

Release notes 

Recommended 

for 5.x 



Le navigateur nous propose alors de sauvegarder une archive ayant pour 
extension . tar . gz, par exemple sur votre bureau. 


Bon A savoir Les outils de decompression 

Pour les windowsiens, les fichiers , tag . gz (ou . tgz) sont des archives Unix compres- 
sees, des fichiers equivalents aux fichiers . zi p. En standard, vous n'avez pas les outils pour 
pouvoir prendre en charge ce type d'archive. 

Pour pouvoir I'utiliser, il faudra telecharger et installer un outil de decompression comme 
WinRAR, WinZip ou 7-Zip. Une fois I'un de ces outils installe, vous pourrez cliquer sur I'icone de 
I'archive telechargee pour en voir le contenu. Generalement, vous disposez aussi d'un menu par 
die droit proposant I'option extraire id (ou extract here) qui nous servira un peu plus loin. 


Telechargement de la traduction franchise de Drupal 

La toute derniere version stable de Drupal est maintenant sur votre bureau 
mais malheureusement il s’agit dune version anglaise. L’etape suivante 
consiste done a recuperer le paquet des traductions pour disposer dune 
version francisee. Notez cependant que les traductions de Drupal sont 
l’oeuvre de benevoles et qu elle ne sont pas parfaites. De plus, ces traduc- 
tions ne prennent pas en compte les modules que nous allons installer. 
Chaque auteur de module est libre de fournir les traductions dans les lan- 
gues qui lui ont ete fournies la aussi par des benevoles. Vous trouverez plus 
d ’informations a ce sujet dans le chapitre 10 « Gerer les langues ». 


• Translations 


Figure 4-13 

La section des traductions 
de drupal.org 


Drupal uses English by default, but may be translated to many other languages. To install these 
translations, unzip them and import the .po file through DrupaPs administration interface for localization. 
You will need to turn on the locale module if it's not already enabled. For up to date information on where 
the translation infrastructure is going, please see the localization server project. 


Pour cela, revenons a la page precedente (section Download ) et selection- 
nons le type de ressource Translations. 

Nous trouvons sur cette page les nombreuses traductions disponibles de 
Drupal. Pour l’instant, concentrons-nous sur la version franfaise ( French ) 
qui se trouve sur la troisieme page. 
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Une fois reperee, comme pour Drupal Core , nous avons en vert les versions 
stables des traductions, et en rouge celles qui ne le sont pas. Preferez les 
versions stables en prenant soin de selectionner la traduction adaptee a la 
version de Drupal que vous utilisez (ici la version 6). Nous sauvegarderons 
cette archive de traduction au meme endroit que celle de Drupal. 


Bon a savoir La stability des langues 

Si vous n'avez pas de version stable pour une 
langue, vous pouvez prendre une version de deve- 
loppement sans trop de risques : au pire, il ne vous 
manquera que certaines traductions. 


Installation des sources de Drupal 

Decompression des archives 

Drupal etant une application PHP, son installation ne se passe pas 
comme pour une application traditionnelle. II s’agira d’abord d ’installer 
le code source de Drupal, ce qui correspond a decompresser les archives 
que nous avons telechargees, puis dans un second temps a installer les 
donnees de Drupal dans une base de donnees MySQL. 

L’installation des sources consiste done simplement a decompresser le 
fichier drupal -6 . 10 . tar . gz, ce qui nous donne un dossier drupal -6. 10. 
Recopiez tout le contenu de ce dossier (n’oubliez pas le fichier 
.htaccess) dans le dossier web (c:\wamp\www pour Windows, et /var/ 
lib/www/html pour Linux). Les sources de Drupal sont maintenant en 
place. Nous allons y aj outer la traduction fran^aise en recopiant l’archive 
fr-6.x-1.0. tar.gz a la racine de notre dossier web et en la decompres- 
sant a cet endroit. Vous pouvez ensuite supprimer l’archive. 

Comprendre la structure des dossiers 

Nous avons a present dans notre dossier web une serie de dossiers dont il 
est important de comprendre l’usage. Meme si vous n’avez aucunement 
l’intention d’aller modifier le fonctionnement interne de Drupal, con- 
naitre cette structure permet de ne pas poser ses fichiers (modules, 
themes, etc.) n’importe ou, ce qui risquerait d’aboutir a une installation 
difficile a maintenir et a faire evoluer. 

• mi sc: ce dossier contient divers elements standards de Drupal 
comme les images, les fichiers JavaScript, etc. 

• modules : ce dossier contient les modules par defaut de Drupal 
(Node, Blog, Book, Comment, etc). Ils forment le coeur des fonc- 
tionnalites Drupal. 

• themes : ici se trouvent les quatre themes par defaut de Drupal, que 
nous etudierons un peu plus loin. 
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• profils : ce dossier contient les profils de configuration utilises lors 
des installations. C’est par exemple ici qu’une partie de notre archive 
de traduction a ete decompressee. 

• i ncl udes : il s’agit la de fensemble des fonctionnalites fondamentales 
de Drupal (gestion du cycle de creation des pages, des themes, des 
bases de donnees, etc.). 

• scri pts : vous trouverez ici des scripts utilitaires que nous etudierons 
un peu plus loin. 

• sites : il s’agit du seul endroit oil vous stockerez tout fichier ne fai- 
sant pas partie de la distribution standard de Drupal. 

Le dossier sites est pour nous le plus important car, repetons-le, il s’agit 
(sans compter profils) du seul emplacement dans lequel nous serons 
amenes a travailler. Considerez d’ores et deja tout autre dossier, y compris 
la racine, comme interdit de modification. Cette bonne pratique vous evi- 
tera de nombreux maux de crane lorsque vous devrez mettre a jour votre 
Drupal. Si vous avez scrupuleusement respecte cette regie, vous n’aurez 
qu’a sauvegarder le dossier sites, ecraser tout le reste avec la nouvelle ver- 
sion, et remettre sites a sa place pour que tout fonctionne de nouveau. 

Comme nous le verrons en detail dans les prochains chapitres, dans ce 
dossier sites nous pourrons Stocker : 

• nos modules ; 

• nos themes ; 

• nos configurations ; 

• les fichiers utilisateur attaches aux contenus. 

Creation du parametrage initial 

Pour l’instant, vous ne trouvez a la racine du dossier sites que deux 
repertoires : all et default. Laissons provisoirement all de cote pour 
nous concentrer sur default. 

Ce dernier contient un seul fichier default . setti ngs . php. Il s’agit de la 
configuration de base de notre site Drupal. Ce fichier est juste un modele 
que nous allons dupliquer au meme endroit sous le nom setti ngs. php. 

Une fois le fichier setti ngs. php cree, nous devons nous assurer que le 
dossier sites et son contenu possedent les droits d’ecriture pour le ser- 
vice Apache, faute de quoi l’installation de Drupal ne pourra pas effec- 
tuer sa configuration automatique pour nous. 

Sous Windows XP, le changement de droits se fait par un clic droit sur 
le dossier sites, en choisissant Proprietes. Dans l’onglet General , deco- 
chez Lecture seule puis cliquez sur Appliquer. 
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profiles 
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General j Rartage j Peraonnaliser | 
fj [sites 

Type : Dossier de fichiers 

Emplacement : C:\wamp\www 

Taille : 17,7 Ko {IS 202 octets} 

Taille sur le 2 S.O Ko {28 G72 octets} 

disque : 

Gontenu : S Fichiers, 2 Dossiers 


Dee le : vendnedi 27fevrier 2000, 0S:5S:23 


£ 


Annuler | Appliquer 


Figure 4-14 

Changement des droits sous Microsoft Windows 


Une confirmation vous est alors demandee pour appliquer les modifica- 
tions a ce dossier et a tous les sous-dossiers et fichiers. Confirmez en cli- 
quant sur OK, puis OK a nouveau. 

Sous GNU/Linux, vous pouvez, dans une console, lancer la commande : 
chmod 111 /var/www/html/si tes -Rc 




Creation de la base de donnees 

Avant d’aller plus loin, il nous faut creer la base de donnees qui heber- 
gera les donnees de notre site. Pour cela, creez un nouvel onglet dans 
votre navigateur (generalement CTRL+T) et allez a fadresse http://localhost/ 
phpmyadmin. 

Ici se trouve foutil phpMyAdmin qui permet de creer, de visualiser et de 
parametrer notre service de base de donnees. Si un mot de passe vous est 
demande, saisissez fidentifiant root et le mot de passe que vous avez 
configure plus haut. 

Une fois sur la page d’accueil de phpMyAdmin, nous avons la possibility 
de creer une nouvelle base de donnees, dans le cadre MySQL localhost. 
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Figure 4-15 

Creation de la base de donnees pour Drupal 


Figure 4-16 

Installation de Drupal : choix de la langue 
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& Greer une base de donnees © 

|colchique| J | Intencbsement | C ] [ Creer | 

EH I nterclassement pour la connexion MySQL: Intenclassement C 

j Executer j © 

Nous saisissons id le nom de notre base de donnees dediee a Drupal, 
colchique, et appuyons sur Creer. La nouvelle base de donnees appa- 
raitra sur le cote gauche de la page. Vous pouvez la selectionner mais elle 
sera en toute logique vide. 


Initialisation de (’installation Drupal 

Les sources de Drupal etant installees, il nous reste maintenant a faire de 
meme avec sa base de donnees. A partir de maintenant, tout se fait a partir 
dun simple navigateur web en allant a l’adresse http://localhost/install.php. 

Selection de la langue 

Notre installation commence par le choix de la langue d’installation qui 
sera aussi celle par defaut de notre site Drupal. Selectionnez French 
(Frangais) et appuyez sur Select language pour passer a 1’etape suivante. 
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Si tout s’est bien passe, Installation devrait sauter 1’etape de verification 
des prerequis. Sinon, notez ferreur rencontree par Drupal et reportez- 
vous a la section « Resolution des problemes techniques », page 60. 
Lorsque le probleme a ete corrige, pressez F 5 pour verifier que Drupal ne 
trouve pas d’autres erreurs. Si aucune erreur ne subsiste, vous passerez 
automatiquement a 1’ etape suivante. 

Configuration de la base de donnees 

Ceci fait, appuyez sur F 5 dans le navigateur pour voir si Drupal a d’autres 
avertissements a nous donner. Normalement, aucun probleme ne devrait 
etre detecte, et le processus d’installation devrait pouvoir avancer a 
l’etape suivante. 



Figure 4-17 

Installation de Drupal : 
configuration de la base de donnees 




Ici, nous allons donner a Drupal les informations lui permettant de con- 
tacter la base de donnees. Tout d’abord, il nous faut choisir le Type de 
base de donnees , en l’occurrence A/lySQL. 

Ensuite nous saisissons le Nom de la base de donnees , a savoir col chi que, 
et enfin le Nom d'utilisateur et le Mot de Passe de l’utilisateur qui sera 
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Figure 4-18 

Installation de Drupal : 
application des traductions 


Figure 4-19 

Installation de Drupal : 
les informations sur le site 


Attention Choix des adresses courriel 

Faites attention, toutes les adresses courriel indi- 
quees dans cet ouvrage le sont a titre d'exemple. 
Lors de vos tests, vous devrez a chaque fois uti- 
liser une adresse reelle pour pouvoir ainsi rece- 
voir les courriels de test envoye par Drupal. Cela 
peut etre votre adresse personnels ou une 
adresse que vous creerez pour I'occasion. 


56 


autorise a se connecter a la base de donnees. Lutilisateur concerne ici est 
root. Pour une installation WAMP, vous n avez pas a saisir de mot de 
passe. Pour une installation LAMP, entrez le mot de passe que vous avez 
choisi lors de Installation de MySQL. 

Ceci fait, cliquez sur Sauvegarder et poursuiure. Une barre de progression 
de 1’installation s’affiche alors pour vous indiquer les operations effec- 
tuees par Drupal. 

Importation de traductions de Pinterface utilisateur 

Reste 0 sur un total de 16. 100% 


Configuration du site 

Un avertissement devrait apparaitre en tete de cette nouvelle page, vous 
indiquant que le fichier settings. php a bien ete modifie et quil nous 
faut maintenant retirer les droits d’ecriture. II s’agit ici d’effectuer Tope- 
ration inverse de celle realisee plus haut, en otant a tout le monde les 
droits sur le dossier sites et ses elements enfants. 

Informations sur le site 

Une fois cette precaution prise, nous procedons au parametrage du site en 
lui-meme. Notez que rien de ce qui est fait ici nest definitif et que tout 
pourra etre change plus tard en passant par Tadministration de Drupal. 


Informations 

Horn du site : 

|ColchiqLie| 

Adresse e-moil du site : 

|we b m aste r@co lchique-conseil.fr 

Le champ De des emails au to matiq ues e nvoy&s pendant la procedure d'enregetrement, les demandes 
de nouveaux motde passe et lesautres notifications. 


Nous commen^ons par les informations de base du site : le Nom du site 
ainsi que Y Adresse e-mail du site. Le Nom du site sera utilise plus tard par 
Drupal en tant que titre du site, en en-tete de toute page. 

Compte administrateur 

Une fois le titre fixe, nous allons creer le compte de Tutilisateur privilegie 
de notre site Drupal. 
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Compte administrateur 


Ljs compte administrateur a un acces complet au site ; il aura automatiquement toutes los 
permissions et pourra effectuer n'im porte quelle tache. Ce compte sera le seul a pouvoir exec u ter 
certaines taches, n'en abusez done pas. 


Nom d'utilisateur : 

[administrateur 

Las spaces so n L auto rises, mais pas las signes de ponctuatbn a reception daa points, tra its d' u n io ns 
et ca lacte les de soulignemenf. 


Adresse electronique : 

[we b m aste r@co Ic h iq ue -co n se i I .f r 


To us les messages de ce systems se ro nt e nvoy^s a cette adresse. Cette adiesse ne sera pas rendue 
publique. et ne seia utilbee que aivous desiiez obtenir un nouveau mot de passe ou race voir 
pe rso n ne lie me n t ce rta ines no uve lies o u eve rtisse me n Is. 


Mot de passe : 



Securite du mot de passe : Haute 


Confirmer le mot de passe : 

»»**»*»*. | Concordance des mots de passe : Oui 


Figure 4-20 

Installation de Drupal : 

reglage du compte de I'administrateur 




II n’y a aucun probleme a utiliser un mot de passe simpliste et facile a 
retenir pour une machine de developpement, mais pour un serveur 
public, ayez conscience que ce compte aura absolument tous les droits. II 
conviendra done d’utiliser un mot de passe complexe. Lors de la saisie, 
un indicateur de solidite est la pour vous aider : vous devez obtenir une 
securite de mot de passe « haute » en melangeant majuscules, minus- 
cules, espaces, symboles et chiffres sur 10 a 12 caracteres. 

Tous les parametres du compte administrates pourront etre changes 
ulterieurement. II suffira pour cela de se connecter en tant qu adminis- 
trates, et d’aller dans Mon compte , puis dans l’onglet Modifier. 

Concernant l’adresse electronique, utilisez votre propre adresse courriel. 
En effet, des que Installation sera achevee, Drupal vous enverra un 
courrier de confirmation indiquant que le compte a ete correctement 
cree. Cette adresse doit done etre valide. 


Bon A SAVOIR Reinitialiser le mot de passe 
administrateur 

Si vous avez perdu des identifiants, sachez que 
tous les comptes utilisateur sont stockes dans la 
table users. 

Dans cette table, a chaque compte correspond un 
id unique (colonne UID). Pour Drupal, les utilisa- 
teurs anonymes et privileges sont systematique- 
ment les deux premieres lignes de cette table, et 
ont pour UID respectif 0 et 1 . 

Pour changer identifiant et mot de passe, il suffit 
d'executer la requete SQL suivante avec la console 
MySQL ou PhpMyAdmin : 
update users set 

name= ’ i denti f i ant_admi ni st rateu r ’ , 
pass=md5 ( ’ mot_de_passe ’ ) 
where 
uid=l; 


Fuseau horaire 


Parametres du serveur 


Fuseau horaire par defaut : 

| samedi, fevrier 28, 2009 - 13:19 +0100 0 | 

Par clefaut, les dates et les heures sur ce site seront afficbees selon ce fuseau horaire. 


Figure 4-21 

Installation de Drupal : parametrage du fuseau horaire 


Le fuseau horaire est utilise par Drupal pour dater les nouveaux contenus, 
les commentaires, les mises a jour, etc. Le choix du fuseau se fait ici sim- 
plement en selectionnant dans la liste celui que vous desirez utiliser. 
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Bon a savoir 

Les URL simplifiees vues par Google 

Le moins qu'on puisse dire est que les URL non 
simplifiees ne sont pas des plus elegantes. Mais 
leur vrai probleme nous est donne dans le guide a 
I'usage des webmestres redige par Google : 

« If you decide to use dynamic pages (i.e., 
the URL contains a "?" character), be aware 
that not every search engine spider crawls 
dynamic pages as well as static pages. It 
helps to keep the parameters short and the 
number of them few. » 

En Somme, en utilisant ce format d'URL, nous ris- 
quons d'avoir des pages non references par cer- 
tains automates de recherche. Ce format n'est 
done pas tres conseille pour augmenter sa visibility 
sur le Web. 


Figure 4-22 

Installation de Drupal : URL simplifiees 


Figure 4-23 

Installation de Drupal : desactivation 
des notifications de mises a jour 


Figure 4-24 

Installation de Drupal enfin terminee ! 
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URL simplifiees 

Comme vous le constatez dans la barre d’adresse du navigateur, Drupal 
utilise par defaut des adresses web de la forme http://ww.colchique- 
conseil.fr?q=/section/page. 

Ce qui se trouve apres le ?q= - dans notre exemple : /section/page 
represente le chemin interne et designe la ressource Drupal a afficher. Le 
mode URL simplifiees permet de se passer du ?q= pour obtenir une adresse 
de la forme http://ww.colchique-conseil.fr/section/page. 

Vous pouvez done ici activer la simplification des URL. Si Drupal vous 
indique que ce n est pas possible, reportez-vous a la section « Resolution 
des problemes techniques », page 60 . 


URLs simplifiees : 

G Desactive 
® Active 

Cette option indique a Drupal d'emettre des URLs "simplifiees" (e'est a dire sans le 7q= dans 
I' URL). 

Le test a reussi. Votre serveur supporte cette fonctionnalite. 


Notification des mises a jour 

Cette option permet a Drupal de verifier regulierement si une mise a 
jour a ete publiee pour Drupal, ou pour lun des modules que vous avez 
installes. Cette option est tres importante, et sur un site de production, il 
ne faudra jamais oublier de Y activer. Cependant, dans le but d’apprentis- 
sage quest le notre, nous allons la decocher. Cela va nous permettre un 
peu plus loin de verifier que Drupal nous previent correctement de cette 
erreur de parametrage. 


Notification des mises a jour : 

□ Verifier automatiquement les mises a jour 


Fin de (’installation 

Nous avons termine cette page de parametrages, et pouvons cliquer sur 
le bouton Sauvegarder et poursuivre. 

Installation de Drupal terminee 

Felicitations, Drupal est maintenant correctement Installe. 

Vous pouvez maintenant vous rendre sur votre nouveau site. 
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Comme Drupal nous l’inclique, notre site est maintenant operationnel. "I 

Nous pouvons cliquer sur le lien Votre nouveau site pour nous en 
convaincre : 


Colchique 


administrateur 

Bienvenue sur votre nouveau site Drupal \ 

Mon compte 

Merci de suivne ces etapes pour configurer et com me ncer a 1'utilsser : 

Creer uncontenu 


Administer 

1 . Configurez votre site web 

Ee deconnecter 

Unefais conroecte, visifez la section d 'admin istration.ou vous pouvez perse 


2 . . Active z dtes f onctio ns s uppfe in e nla ires 


Ensuite, visitez la listedes modules et aclivez les forte tionnalites qui convie 

modules dans la section de tie lech argementde modules de Drupal, 


3. Personnalisez lapparence de votre site web 


Pour changer Pap p a nence et lecomportementde votre site web, visitez la si 
ou le lee hanger d'autres the me e dan e la section de le fee h angeme nt dec then 


4. Commencez a contribuer 


Enfin, vous pouvez creer du conte nu pour votre site web, Ce message dlsp 

d'accueil. 


Figure 4-25 

La page d'accueil de Drupal 




Si tout s’est bien passe, vous devriez recevoir le courrier de confirmation 
de la creation du compte administrateur. Si vous ne le recevez pas, vous 
avez surement un probleme dans votre chaine d’envoi de courrier, 
reportez-vous a la section « Resolution des problemes techniques » page 
suivante pour plus d’informations. 


ASTUCE Et si on recommen^ait depuis le debut ? 

Question saugrenue de prime abord mais qui n'est neanmoins pas denuee d'interet. En effet, 
vous avez peut-etre simplement envie de verifier ce que vous venez d'apprendre depuis le 
debut ? 

Pour recommencer Installation, vous devez effectuer les etapes suivantes : 

1. Ecraser le fichier settings, php avec la version qui vous a ete fournie par defaut 

setti ngs . def aul t . php. 

2. Supprimer la base de donnees avec phpMyAdmin, en selectionnant la base de donnees 
col chi que et en diquant sur I'onglet Supprimer. 

C'est tout ce qu'il y a a faire pour recommencer installation de Drupal a partir de I'adresse 
http://localhost/install.php. 


ASTUCE Parametrage du nom de domaine 

Cette etape n'est en soi pas necessaire mais pour 
la suite de cet ouvrage, nous n'utiliserons plus 
I'URL http://localhost/ mais celle-ci : http:// 
www.colchique-conseil.fr. Si vous aussi vous 
desirez utiliser cette seconde URL, c'est possible en 
ajoutant la ligne suivante dans votre fichier 
hosts. 

www.colchique-conseil .frl27.0.0. 1 
Sous Linux, le fichier hosts se trouve dans 
/etc/hosts, sous Windows, C:\WINDOWS\ 
system32\dri vers\etc\hosts. II suffit 
d'ajouter cette ligne et d'enregistrer le fichier pour 
que le nouveau nom soit accessible dans votre 
navigateur. 
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Resolution des problemes techniques 

Dans cette section, nous allons aborder divers problemes techniques que 
nous pouvons rencontrer au cours du processus d ’installation. 


Problemes de droits 

Lors de la phase de verification des prerequis, si vous obtenez le message 
suivant : 


Figure 4-26 

Premier message d'erreur lie aux droits 
lors de ('installation 


Figure 4-27 

Second message d'erreur lie aux droits 
lors de ('installation 

... vous n’avez probablement pas correctement parametre les droits 
d’ecriture a Apache pour le dossier sites. Reportez-vous a la section 
« Initialisation de Installation », rubrique « Creation du parametrage 
initial » pour plus d’informations. 

Mauvais fichier de configuration 

Si vous obtenez lors de la phase de validation des prerequis le message 
d’erreur suivant : 

Figure 4-28 Copier le fichier ./sites/defauitfdefauit. settings.php en , /site s/default 

Message d'erreur lie a I'absence / settings.php . 

de settings.php 

. . . vous avez sans doute oublie de recopier le modele configuration vers 
une configuration par defaut. Reportez-vous a la section « Initialisation 
de l’installation », a la rubrique « Creation du parametrage initial » pour 
plus d’informations. 


60 


ou encore : 

Le repertoire sites/default/files n'existe pas. L'essai de creation automatique 
de ce repertoire a echoue, probablement du fait d'un probleme lie aux 
permissions. Pour proceder a ^installation, vous pouvez soit creer un 
repertoire et regler ses permissions manuellement, ou assurez-vous que 
I'installeur possede les permissions necessaire pour le creer 
automatiquement. Pour plus d'information, consultez le fichier INSTALL.txt ou 
le manuel en ligne. 


Changer les droits des fichiers pour qu'ils soient autorises en ecriture 
par le serveur web. Si vous ne savez pas comment attribuer les droits, 
consultez le manuel en ligne. 
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Impossible d’activer les URL simplifies 

II est possible que Drupal vous interdise le choix Active pour cette 
option, ce qui se traduit par le message suivant : 


La configuration de votre systems ns supports pas cette fonctionnalrte. La page du manuel sur les 
URLs simplifies apporte une aide supplementaire. 


Figure 4-29 

Message d'erreur portant sur I'impossibilite 
d'activer les URL simplifies 


La raison est generalement une incompatibility entre cette option et le 
parametrage du service Apache. En effet, le mode URL simplifies uti- 
lise le module Apache mod_rewrite pour reecrire les requetes avant de 
les transmettre a Drupal. Le principe est le suivant : mod_rewrite trans- 
forme toute requete de la forme http://www.conchique-conseil.fr/a/b/c en 
http://www.conchique-conseil.fr?q=a/b/c, permettant ainsi a Drupal de retomber 
sur son mode natif (avec ?q=) . 

Les regies de reecriture de requetes sont stockees dans le fichier 
.htaccess qui se trouve a la racine du site Drupal. Si le mode nest pas 
activable, soit le module Apache mod_rewrite n est pas installe, soit il est 
installe mais futilisation des fichiers .htaccess est interdite par votre 
configuration Apache. 

Dans les deux cas, la solution se trouve dans le fichier httpd.conf (situe 
dans /etc/httpd/conf pour GNU/Linux, et dans Apache/httpd . conf 
pour fenvironnement WAMP). II s’agit d’y verifier que le module 
mod_rewrite est bien charge : 

LoadModule rewri te_modul e modul es/mod_rewri te . so 

Ensuite, cherchez un peu plus loin dans la configuration la directive 
Directory portant sur c:\wamp\www et verifiez que vous avez bien une 
commande A1 1 owOverri de All. 

<Di rectory "/var/www/html "> 

A1 1 owOverri de All 

</Di recto ry> 

Lorsque vous aurez effectue les modifications, vous pourrez redemarrer le 
service Apache et rafraichir la page de Installation Drupal sur votre navi- 
gateur. Vous devriez maintenant avoir la possibility d'activer cette option. 
Si Drupal vous affiche une erreur indiquant que le site est deja installe, 
placez le curseur de la souris a la fin de fadresse courante dans la barre 
d’adresse du navigateur, et appuyez sur Entree pour recharger la page. 
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Lorsque vous avez saisi le nom de votre base de donnees ainsi que vos 
identifiant et mot de passe, si vous obtenez l’erreur suivante : 


Figure 4-30 

Message d'erreur lie a 
une base de donnees non accessible 


Impossible de selectionner votre base de donnees sur le serveur MySQL, ce qui 
signifie que le nom d'utilisateur et le mot de passe sont bons, mais qu'il y a un 
probleme pour acceder a vos donnees. MySQL a repondu : Unknown database 
'site_xyq\ 
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. . . vous devez verifiez dans l’ordre : 

1 que le service de base de donnees est bien demarre. Pour cela, allez a 
FURL http://localhost/phpmyadmin ; 

2 que le type de base de donnees choisi est bien le bon ( mysql ) ; 

3 que vous avez bien cree votre base de donnees. Pour cela se reporter a 
la section « Initialisation de Installation », rubrique « Creation de la 
base de donnees » ; 

4 que le nom de lutilisateur est bien root et que le mot de passe est bien 
celui que vous avez configure. Si vous n avez configure aucun mot de 
passe (cas d une installation Windows), ce champ doit etre vide. 

Courrier de confirmation non recu 

Si vous ne recevez pas le courrier de confirmation de votre compte admi- 
nistrateur, il s’agit surement d’un probleme de parametrage dans fenvoi 
des courriers du cote de PHP 

Sous GNU/Linux, ceci ne pose pas de probleme, le courrier emis par 
PHP etant pris en charge par la commande sendmail. Si votre GNU/ 
Linux est correctement configure, par exemple par installation d un 
service PostFix local, les messages devraient partir correctement. Vous 
avez cependant la possibility d utiliser un service de courrier externe 
(SMTP) en utilisant foutil ssmtp. Un tutoriel sur cette technique est 
disponible a fadresse http://artisan.karma-lab.net/node/1171. 

Sous Windows, en revanche, il est important d’indiquer a PHP quel est 
le service de courrier utilise. Vous utiliserez pour cela fadresse du service 
qui vous aura ete donnee par votre fournisseur d’acces a f Internet : allez 
dans le menu WAMP et selectionnez PHP/php.ini. Notepad devrait 
s’ouvrir avec la configuration de PHP. Recherchez la section mail 
function et modifiez comme suit : 

[mail function] 

; For Win32 only. 

SMTP = addresse_SMTP_FAI 
smtp_port = 25 
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II suffit maintenant de quitter Notepad en sauvegardant la configuration 
de PHP, puis de redemarrer les services WAMP. 


En resume 

• Pour fonctionner, Drupal a besoin de PHP 5.0 et d’un service HTTP 
(Apache ou IIS feront faffaire). 

• Toutes les ressources pour Drupal (Drupal lui-meme, les traductions, 
les modules, les themes) sont disponibles sur le site http://drupal.org. 

• Si vous avez des questions a propos de finstallation, n hesitez pas a 
les poser sur le forum en fran^ais dedie a Drupal, a fadresse 
http://drupalfr.org/forum dans la rubrique Avant installation. 


Bon A SAVOIR Comment poser une question sur un forum ? 

• Commencez par faire une recherche sur votre moteur prefere 
(Google, Yahoo!, etc.). La plupart des informations sont en anglais, 
done si vous le pouvez, formulez votre recherche en fran^ais, puis en 
anglais. 

• Si vous ne trouvez rien, posez votre question sur le forum (apres avoir 
verifie qu'aucune autre question similaire n f a deja ete posee). Soyez 
certain qu f il n'en existe pas de mauvaise. Poser une question, e'est 
aussi une maniere de contribuer au projet Drupal car les questions 
(ainsi que leurs reponses) seront un jour indexees dans les moteurs de 
recherche. 

• Soyez precis dans vos formulations. Redigez des phrases completes, 
en frangais (bannissez tout langage abrege, SMS, etc.) et comprehen- 
sibles par tous. Donnez toujours le contexte de votre probleme (ver- 
sion exacte de Drupal, nom et version des modules, etc.). 

• Lorsqu f un contributeur vous aura donne la bonne reponse, remer- 
ciez-le et modifiez le sujet de votre question pour faire preceder le 
titre de [Resolu]. 
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M Colchique 


Aecueil ► Administrer 


administrateur 


Administrer 


Par tache 


Par module 


O Moncompte 
l> Greer un contenu 
Administrer 
[> Construction du site 
Gestion du contenu 
£ Co nf ig u ratio ndu s ite 
[> Ge stio n de s uti I i s ate lj rs 
Rapports 
O Aide 


Cette page liste les taches d'administration disponibles pourchaque module. 


Block 

Contrdle I’affichagedes boites apparaissant on marge du 
contenu principal. 

o Configurer les droits d'acces 
° Blocs 
o Aide 


Comment 

Permetaux utilisateurs decommenteretdediscuter le contenu 
publie. 

o Configurer les droits d'acces 
° Commentaires 
o Aide 


O Se deconnecter 


Database logging Filter 

Consigne les evenements systemes dans la base de don nees. Gere lefiltragedu contenu avant son affichage. 


O E ntree s rice nte s d u jo u rn al 
O Jo u rn al i s atio n e n b ase de do n nee s 
° Princip ale s e rre u rs de type 'acce s ref u se 1 
O P ri nc i p ale s e rre u rs de type 'p age no n tro uvee ' 
O Aide 


O Co nf ig u re r le s d ro its d 'acce s 
O Formats die ntree 
° Aide 

Menu 

Permet aux administrateurs de poison naliser le menu de 

nau ina+inn Hu c™ Hv*. 
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Administrer Drupal 
et ses modules 


La page de bienvenue de Drupal nous propose de commencer 
le voyage par la configuration de notre site web. Cela peut 
paraitre etonnant mais ne manque pourtant pas de sens. Nous 
allons en effet passer beaucoup de temps dans cette zone du 
produit pour creer du contenu, modifier les reglages predefmis 
a Installation et batir la structure des pages. Autant se 
familiariser le plus rapidement possible avec interface 
d’administration, et en appliquer les principes a une tache qui 
reviendra souvent : Y installation de nouveaux modules. 


SOMMAIRE 

► Premiers regards sur 
I'administration de Drupal 

► Les modules : en trouver 
et en ajouter 

► Simuler le cron de Drupal 
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Acceder a I’administration 

Le reproche le plus frequemment adresse a Drupal est lie a son interface 
d’administration, jugee moins accessible que celle de Joomla. C’est assez 
difficile a nier, mais il est important de comprendre que ce parametrage 
complexe au premier abord est la ran^on de possibility etendues. 

Pour acceder aux sections d’administration, il suffit simplement de cli- 
quer sur le lien Administrer a gauche de l’ecran, dans la zone marquee 
administmteur. 


Figure 5-1 

Le menu des actions realisables 
par I'administrateur 


administrateur 

Mon compte 
Greer un contenu 
Administrer 
Se diconnecter 


La page s’affichant a present est dense, aussi, pour bien se reperer, est-il 
primordial d’en comprendre la structure. Celle-ci se compose de cinq 
sections ayant chacune un role precis. 

La construction du site 


Figure 5-2 

La section de I'administration dediee 
a I'ajout de fonctionnalites 


Construction du site 

Contnoler raffchage Qt le cornportBmsnt cte votre site 


Comme son nom le laisse presager, cette section regroupe tout ce qui 
permet d’ajouter des fonctionnalites au site. C’est ici que seront geres les 
themes visuels, les traductions de l’interface, les nouveaux menus, les 
blocs a disposer autour d’un contenu, et enfin les modules. 

Meme si nous y reviendrons rapidement, retenons pour le moment 
qu’un module est un greffon (plug-in) pour Drupal, le dotant de nou- 
velles fonctionnalites. 
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La configuration du site 

De maniere generale, vous passerez beaucoup de temps dans cette sec- 
tion lors de la phase de construction de votre site (d’oii le titre), et beau- 
coup moins une fois que ce dernier sera en production. 
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Figure 5-3 

Configuration du site l_ a section dediee au parametrage 

Ajuster b configuration de basedu sits. . r . , 

des fonctionnalites 




O 

E 


Contrairement a Construction du site oil s’effectue l’ajout de nouvelles 
fonctionnalites visuelles ou non, cette section permet de gerer tous les 
reglages des fonctions existantes. Ici nous n ajoutons done rien, nous ne 
faisons que parametrer. 

Cela comprend un choix d’options comme le format des date et heure, le 
titre du site, factivation ou la desactivation des URL simplifies, etc. 
Vous y retrouverez done beaucoup de reglages que vous avez definis lors 
de Installation de Drupal. 

Ici aussi, la majorite du temps passe le sera au moment de la fabrication 
de votre site. Plus tard, vous y reviendrez surtout lorsque vous devrez 
configurer de nouveaux modules que vous aurez ajoutes. 

La gestion des utilisateurs 


Gestion des utilisateurs 

Gerer les utilsateura de votre site, les groupes et I'accGs aux 
fdnctbnnalltes. 


Figure 5-4 

La section dediee a la gestion des utilisateurs 


Ici pas de mystere : vous allez pouvoir gerer vos utilisateurs (noms, mots de 
passe, etc.), ainsi que les permissions qui leur seront donnees sur les diffe- 
rentes fonctionnalites du site. Notez seulement que nous parlons bien 
d utilisateurs et non de contenus generes par les utilisateurs (articles, com- 
mentaires, etc.), qui eux sont pris en charge par la section suivante. 

Mis a part la definition des roles generalement realisee pendant la phase 
de developpement, nous sommes ici dans une section qui est davantage 
utilisee pendant la phase d’exploitation de votre site, une fois qu’il aura 
ete mis en production. 

La gestion du contenu 


Gestion du contenu 

Geror Is contenu de votre site. 


Figure 5-5 

La section dediee a la gestion des contenus 


Vous trouverez ici tout ce qui concerne le contenu au sens CMS du 
terme, e’est-a-dire la creation de nouveaux types de contenu, la gestion 
des commentaires et des contenus deja ecrits, la taxonomie, etc. 
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Comme pour la section Gestion des utilisateurs, une fois vos types de con- 
tenu et vos taxonomies regies, vous passerez beaucoup de temps dans 
cette section apres la mise en ligne de votre site pour gerer les contenus 
existants et les commentaires associes. 

Les rapports 


Figure 5-6 

La section permettant d'acceder a tous les 
rapports sur le fonctionnement de Drupal 


Rapports 


Voir les rapports des journaux du systems* etdlautnes informations. 


Cette section vous donne acces a une serie de pages permettant de con- 
naitre l’etat de Drupal. Vous y trouverez, par exemple, la liste des pages 
en erreur, le journal des erreurs emises par les modules, ou plus impor- 
tant, le tableau de bord vous permettant d’avoir une vision generale de la 
bonne marche du systeme. 


Terminer I’installation de Drupal 


Figure 5-7 

Message prevenant I'administrateur 
d'un mauvais parametrage 


Utilisation du tableau de bord 

Interessons-nous a present au message qui se trouve en haut de la page 
d’administration et qui devrait ressembler a ceci : 


Un ou plusieurs problemes ontete detectes dans votre installation de Drupal. Verifiez le tableau de 
bord pour plus d 'information. 


Par ce message, Drupal nous indique quil a detecte des problemes d’ins- 
tallation. Pour savoir de quoi il en retourne, nous pouvons soit cliquer 
sur le lien Tableau de bord du message, soit - ce qui revient strictement 
au meme - sur le lien Tableau de bord de la section Rapports. 

Sur cette page apparait une liste de points que Drupal a cherches a verifier. 
Ici nous avons deux erreurs (fond rouge) et une alerte (fond jaune). Le 
premier point porte sur le fait que nous avons oublie d enlever a Apache 
les droits en ecriture sur le dossier sites/default et le fichier sites/ 
default/settings. php. Nous pouvons corriger cela tres facilement 
comme nous favons vu au chapitre precedent. II suffit alors de rafraichir la 
page pour verifier que la modification est bien validee par Drupal. 
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Drupal 

6.13 

Acces au fichier update. php 

Protege 

Base de donnees PostgreSGL 

8.3.7 

<3 Fichier de configuration 

Non protege. 

Le repertoire sites/default n'est pas protege en ecriture. Cel a pourrait poser un probleme de sec u rite, vous devez done changer les 
permissions du fichier pourqu'il ne soit pas accessible en ecriture. Le fichier sites/default&ettingsjihp n lest pas protege en ecriture et 
cela pose un probleme de securite. Vous devez changer les permissions du fichier pourqu'il ne soit pas accessible en ecriture. 

Libra iris CD 

2.0 or higher 

Libra iris Unicode 

Extension PHP mbstring 

Mise a jour de Li base de donnees 

A jour 

|\ Notification des mises a jour 

Non active 

Les notifications de mise a jour ne sont pas activees. 
d'administration des modules pour nester informe des 

manuel. 

II est forte merit recommande d 'active r le module update status depuis la page 
mises a jour. Pour plus d'information veuillez lire la page Update status du 

y php 

5.2.9 

PHP 'register globa Is' 

Des active 

Plafond memoire de PHP 

256M 

Serve ur web 

Apache/2.2.1 1 (Mandriva Linux/PR EFOR K-1 0.1 mdv2009.1 ) 

Systeme de fichiers 

Inscriptible (methode de telechargementpdj , 5//qtre) 

<3 Taches de maintenance cron 

Derniere execution, il y a 4 semaines 2 jours 

Cron n'a pas ete lance necemment. Pour plus d 'informations reportez-vous a Hentree sur la configuration du Cron du manuel en ligne. 
Vous pouvez lancer le cron manuellement. 


LO 


Figure 5-8 

La liste des points verifies par 
Drupal, et des erreurs detectees 




Fichier de configuration 


Figure 5-9 

Les fichiers sont maintenant proteges. 


La tache de maintenance cron 

La deuxieme erreur detectee par Drupal porte sur « cron » qui n aurait 
jamais ete execute. Un peut deroutant tout de meme si Ton ne sait pas ce 
quest ce cron... 

Cron est un mecanisme de Drupal lui permettant d’effectuer des actions 
a intervalles de temps reguliers, comme envoyer des bulletins d ’informa- 
tions ou des courriels de notification, nettoyer la base des messages 
d’erreur, verifier si votre systeme est a jour, etc. En bref, cron est indis- 
pensable au bon fonctionnement de Drupal, ce qui explique que son 
dysfonctionnement detecte ici soit considere comme une erreur grave. 

De maniere plus pragmatique, cron est un simple script PHP appele 
cron.php qui se trouve a la racine, a cote d’index.php. Pour lancer les 
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actions de maintenance, il suffit done d’executer ce script manuellement 
en cliquant sur le lien lancer le cron manuellement indique dans l’erreur 
du tableau de bord. Apres un petit temps d’attente, Drupal vous affiche 
le message suivant : 


Figure 5-10 

Cron s'est correctement execute. Traitement rSgulier (cron) neussi. 


Et tres logiquement, le message d’erreur du tableau de bord a disparu, 
vous indiquant la derniere fois que cron a ete execute et vous redonnant 
le lien pour le lancer a nouveau. 


Figure 5-11 

L'erreur cron a maintenant disparu. 


Taches de maintenance cron 

Vous pouvez lancer le cron manuellement. 


Derniere execution, il y a 1 sec 


HlSTOlRE D'oii vient cron ? 

Cron est a I'origine un programme Unix qui fonc- 
tionne en permanence (ce genre de programme est 
appele un demon, daemon en anglais) et qui exe- 
cute des taches programmes a intervalles de 
temps reguliers. C'est Equivalent du planificateur 
de taches sous Microsoft Windows. Le nom cron 
en lui-meme vient de Chronos, qui n'est autre que 
le dieu grec personnifiant le temps. 


Bien evidement, lancer le cron manuellement nest pas une option valable 
lorsque notre site sera en production. Nous verrons done au chapitre 
« Mettre son site en production » comment automatiser ce processus. 
Mais pour notre plate-forme de developpement, cette methode manuelle 
convient parfaitement. Elle nous permet en effet de tester les taches de 
maintenance sans avoir a attendre qu elles s executent toutes seules. 

Ainsi, tout au long de cet ouvrage, et a chaque fois que cela sera neces- 
saire, nous reviendrons sur le tableau de bord pour lancer nous-meme la 
tache cron. 


La gestion des modules 


Figure 5-12 

Une demande insistante pour activer 
le module Update status 


!\ Notification des mises a jour Non active 

Lea notification a de miae a jour ne aont pas activees. II est forte me nl 
recommande d 'activer le module update status depuis la page d'administration 
dea modules pour neater informe dea miaes a jour. Pour plua d'information veuillez 
life la page Update status du manuel. 


Il nous reste encore une erreur, ou plutot un avertissement, dans notre 
tableau de bord, nous enjoignant d’activer un certain module Update 
status. Voyons maintenant comment faire une telle chose. 
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Activer et desactiver un module 

Les modules sont la composante fondamentale de Drupal, il est done 
important de comprendre comment les utiliser. 
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Dans le message d erreur sur la Notification des mises a jour , le tableau de 
bord nous propose un lien direct vers la page d’ Administration des modules. 
Nous pourrions l’utiliser mais il est plus interessant d’apprendre le chemin 
normal qui mene a ce lieu oil nous allons passer beaucoup de temps. 

L’administration des modules fait partie de la section Construction du site. 
Nous pouvons y acceder en utilisant a nouveau le menu Administrateur 
sur le cote droit et en cliquant sur Construction du site. Le menu se 
deroule alors pour faire apparaitre les differents aspects de la construc- 
tion, dont la section Modules sur laquelle nous cliquons. 

Sur cette nouvelle page apparait la liste des modules installes par defaut 
avec Drupal. Comme vous le voyez, ils sont regroupes en deux 
categories : Core -facultatif et Core - obligatoire. 


<v 


© 

E 


Ergonomie Les zones depliables 

Les categories sont des zones qu'il est possible de 
deplier et de replier en cliquant sur le triangle a 
gauche du libelle. Cette ergonomie est utilisee un 
peu partout dans Drupal. Par defaut, certaines 
zones sont depliees et d'autres non. II s'agit gene- 
ralement de differencier les options avancees 
(repliees) des standards (depliees). 


j" Gore - obligatoire! 


Active 

Norn 

Version 

Description 

0 

Block 

6.13 

Controle I'affichagedes boTtes apparaissant en marge du contenu principal. 

0 

Filter 

6.13 

Gere lefiltrage du contenu avant son affichage. 

0 

Node 

6.13 

Permetdesoumettredu contenu au siteetde I'affichersur les pages. 

0 

System 

6.13 

Permet aux administrateurs de modifier la configuration generale du site. 

0 

User 

6.13 

Gere I'inscription des utilisateurs et lesystemed'identification. 


Figure 5-13 

Les modules du coeur de Drupal 


Core (en fran^ais, coeur) fait reference aux fonctionnalites de base de 
Drupal. Nous avons ainsi les modules de base obligatoires, gerant les 
fonctions fondamentales d un CMS. 

Block : nous allons bientot decouvrir ce module, les blocs ayant un role 
important dans Drupal pour creer la presentation de notre site. Ce 
module est responsable de leur affichage. 

Filter : ce module sera etudie plus en detail dans le chapitre 7, section 
« Ajouter de nouveaux filtres ». Son role est de permettre la prise en 
charge de syntaxes particulieres (HTML, Wiki, etc.) pour le corps des 
contenus et des commentaires. 

Node : un module absolument central car il est charge de la gestion des 
contenus eux-memes. En vocabulaire Drupal, un contenu s’appelle 
d’ailleurs un node (noeud). 

User : le module qui gerera les utilisateurs authentifies, c’est-a-dire ceux 
qui sont connus du site et qui s’y connectent par un identifiant et un mot 
de passe. 

La case a cocher qui precede chaque module indique si ce dernier doit 
etre active ou desactive. Comme vous le voyez, beaucoup de modules 
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Bon a SAVOIR Les modules et le francais 

Chaque module est fourni avec un certain nombre 
de traductions disponibles. Lorsque Ton active un 
module, Drupal y cherche une langue correspondant 
a la langue courante, ici le frangais. S'il la trouve, il 
I'installe. Le module active sera done disponible en 
frangais. Cependant, beaucoup de modules ne sont 
pas traduits, nous verrons un peu plus loin comment 
effectuer cette traduction nous-meme. 


Figure 5-14 

Nous avons la confirmation 
que notre Drupal est bien a jour. 


Figure 5-15 

Tri de ('administration par modules 
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facultatifs sont desactives. Evidemment, ceux qui sont dans la categorie 
Core - obligatoire sont tous actives. 

Dans la categorie Core - factultatif, nous trouvons vers la fin de la liste le 
module Update status. C’est ce module que le tableau de bord nous 
reprochait de ne pas avoir active. Cochez done la case qui le precede et 
en bas du formulaire, appuyez sur le bouton Enregistrer la configuration. 

Lorsque la page se rafraichit, le module Update status reste coche, il est 
done active. Nous venons d’activer notre premier module et si nous 
retournons sur le tableau de bord, ce dernier nous en remercie en nous 
affichant un nouvel avertissement, cette fois pour indiquer qu’il nous 
faut relancer cron. En effet, le module Update status ajoute a cron une 
nouvelle tache de maintenance consistant a chercher sur le site drupal.org 
la derniere version de Drupal pour verifier que nous possedons bien la 
toute derniere version. Lancez done a nouveau le cron manuellement, et 
cette fois, tous les indicateurs doivent etre au vert. 


Etat de misea jour de Drupal core 


A jour 


Vous voyez ainsi le premier interet de ce module que nous venons d’activer : 
nous tenir en permanence informe des nouvelles versions de Drupal. 

Trier I’administration par modules 

Le probleme lorsque Ton active un nouveau module est qu’il n est pas aise 
de savoir comment le parametrer. Fort heureusement, il existe une solution 
elegante a ce probleme qui consiste a trier 1’ administration non plus par 
grandes sections, mais par modules. Pour ce faire, retournez sur la page 
d’administration. En haut de la page, vous trouverez deux onglets. Par 
defaut, et c est le mode que nous utilisions jusqu’alors, longlet selectionne 
est Par tache. Cliquez maintenant sur Fonglet Par module. 


Administrer Par tache 


Cette page liste les taches d'administration disponibles pour chaque module. 


Sur cette nouvelle page, nous trouvons une liste des modules disposes en 
sections sous lesquelles sont disponibles les actions d'administration spe- 
cifiques a chaque module. Il est maintenant aise de chercher le module 
que nous venons d’activer pour decouvrir les entrees ajoutees. 
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Update status 

Verifie la disponibilite de mises a jour de Drupal et de vos modules et 
themes installes. 


Mises a jourdisponibles 
Q Aide 


Figure 5-16 

La section d'administration dediee 
au module Update status 


Nous avons ici deux menus ajoutes, A/1 ises a jour disponibles et Aide. Le 
second est disponible pour chacun des modules, et en cliquant dessus, 
vous pouvez savoir ce que chacun fait exactement. 

Update status 

Le module Update status verifie periodique merit ladisponibilite de nouvelles version pour le logiciel de Figure 5-17 

votre site (incluant les modules tiers et les themes) etvous alerte des nouvelles mises ajour. Information SUL le module Update StatUS 


Cette page contient de precieux renseignements et fournit des liens vers les 
differentes fonctions du module. A la fin de cette page, une section reprend 
la liste des fonctions d'administration publiees par le module. Nous y trou- 
vons le lien Mise a jour disponibles sur lequel nous allons cliquer. 


Ergonomi De I'aide pour ('administration 

Dans le menu d'administrateur, I'aide est aussi dis- 
ponible si vous depliez le menu Administrer. 


Accueil » Administrer * Rapports 


Mises ajour disponibles 


Parametnes 


Ici vous pournez tnouverde I 'information a propos des mises a jourdisponibles pour vos modules et themes installes. Veuillez noterque 
chaque module ou theme fait partie d’un "projet", lequel peutou non avoir le meme nom et peut inclure plusieurs modules ou themes. 

Afin dletendre les fonctionnalites ou de changer I'appanence de votre site, un certain nombre de modules tiers et themes sont disponibles. 

Derniere verification : il y a 1 6 min 12 sec (Verifier manuellement) 

Drupal core 

Drupal 6.13 Ajour Z 

Contient : Block, Book , Color , Comment Contact , Database logging, Filter, Garland, Help , Locale , Menu, Node, OpenID, PHP filter. Path, 
Search, System, Taxonomy, Trigger, Update status, Upload, User 


Figure 5-18 Le rapport du module Update status 


Nous voyons ici, dans la zone en haut de la page appelee « fil d’Ariane » 
( breadcrumb en anglais), que nous sommes dans la section Rapports de 
Tadministration. 

Les modules standards 

Avant d’aller plus loin et voir comment aj outer de nouveaux modules, il 
est interessant d’apprendre a connaitre ceux que nous avons en standard. 
Nous allons profiter de cette exploration pour activer un certain nombre 


Anoter Les versions de ce livre 

Ne vous inquietez pas si les versions des modules 
ne sont pas les memes sur votre ecran : Drupal est 
un produit tres vivant qui evolue rapidement et il y 
aura done surement eu des mises a jour depuis la 
redaction de ce livre, comme il y en a eu pendant 
sa redaction. 
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de modules qui ne le sont pas par defaut, prenez done soin de selec- 
tionner les cases a cocher en accord avec les copies d'ecran. 
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Figure 5-19 

Les modules standards de Drupal, 
d'Aggregator a Contact 


□ 

Aggregator 

6.13 

Agregedu contenu syndique (flux RSS, RDF et Atom). 

□ 

Blog 

6.13 

Permet de maintenirdes pages webd'utilisateurs ou des blogs tenus a jourfacilementet regulierement. 

□ 

Blog API 

6.13 

Permet aux utilisateurs de poster en utilisant les applications qui supported les API XML- RPC. 

0 

Book 

6.13 

Permet aux utilisateurs destructurer les contenus du sitede maniere hierarchique. 

0 

Color 

6.13 

Permet a I'utilisatBurde modifier le schema decouleurde certains themes. 

0 

Comment 

6.13 

Permet aux utilisateurs de commenter et de discuter le contenu publie. 

Requiapar : Forum (disabled), Tracker (dibbled) 

0 

Contact 

6.13 

Permet I'utilisation de formulaires de contact a la Ibis pour I'ensembledu siteet pourchaque utilisateur. 


ANOTER Modules magiques 

Le module Forum de Drupal est par defaut assez 
simple. Notez cependant qu'il peut etre etendu 
considerablement par d'autres modules tels que 
Advanced forum (http://drupal.org/project/ 
advanced_forum) qui vise a le faire approcher du 
celebre phpBB. 


Aggregator : ce module nous permettra de combiner des flux RSS prove- 
nant d'autres sites que le notre, et de disposer les resultats sous la forme 
de listes navigables. A bien des egards, ce module permet de fabriquer ce 
que f on appelle des « planets », e'est-a-dire des sites dont l'objectif est de 
synthetiser l'activite d'une myriade d'autres sites axes sur un sujet donne, 
comme le fait par exemple http://planet-libre.org ou encore le planet de 
Drupal France, http://planete.drupalfr.org/. 

Blog et Blog API : ces modules permettent de transformer Drupal en un 
systeme de blog permettant d'accueillir plusieurs bloggeurs comme le 
ferait un site tel que http://overblog.com. 

Book : ce module permet de creer des contenus de type « page d'un 
livre ». Ces contenus ont la caracteristique de pouvoir etre organises les 
uns par rapport aux autres sous la forme de chapitres, prefaces, etc. C'est 
le module ideal pour creer une documentation collaborative. 

Color : ce module qui doit etre active fournit des fonctionnalites au 
moteur de theme que nous etudierons dans le chapitre 11 « Modifier 
l'apparence ». 

Comment : il s'agit la d'un module quasiment obligatoire permettant aux 
utilisateurs de commenter les contenus. 

Contact : ce module va ajouter des formulaires de contact a notre site 
ainsi qu'aux utilisateurs. II faut l'activer. 

Content translation et Locale : nous l'etudierons un peu plus loin dans ce 
livre, ces modules permettent de disposer d'un meme contenu et d'une 
interface en plusieurs langues. 

Database logging : ce module, active par defaut, prend en charge les traces 
d'execution laissees par les autres modules. 

Forum : ce module ajoute a Drupal la capacite d'accueillir un systeme de 
forum complet comme le proposerait phpBB. 
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Menu : un autre module presque obligatoire vous permettant de creer vos 
propres menus semblables au menu administrateur. 




O 
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□ 

Content 

translation 

6,13 

Permet au contenu d'etre tradu it dans plus leu rs langues. 

Depend de : Locale (enabled) 

0 

Database 



logging 

6.13 

Consgne les evenements systemes dans la base de don nees. 

□ 

Forum 

6.13 

Rend possible les fife de discuss bn a pnopos de sujets generaux. 

Depend de : Taxonomy (enabled), Comment (enabled) 

0 

Help 

6.13 

Permet de gerer I'affichage de I'aide en ligne. 

0 

Locale 

6.13 

Ajoute des fionctbnnalit^s degestbn des bngues et permet latraductbn de I'interface utilfeateur 
Requis par : Content tranalation (disabled) 

0 

Menu 

6.13 

Permet aux adminfetrateurs de person naliser le menu de navigatbn du site. 


Figure 5-20 

Les modules standards de Drupal, 
de Content translation a Menu 


LO 


□ 

OpenID 

6.13 

Permet aux utilfeateurs des'identifiersur votresiteavec leur OpenID. 

0 

Path 

6.13 

Permet aux utilfeateurs de renommer les url. 

0 

PHP filter 

6.13 

Permet a du code PHP d'etre evalue a I'interieur des contenus. 

□ 

Ping 

6.13 

Alerte dlautres sites quand votre site a ete modifie. 

□ 

Poll 

6.13 

Permet a votre site de collecter des votes sur differents sujets sous la ft 

□ 

Profile 

6.13 

Gere des pnofife utilfeateurs configu rabies. 

0 

Search 

6.13 

Permet la recherche par mots-cles dans I'ensembledu site. 

□ 

Statistics 

6.13 

Enregfetre les statfetiques dlacces a votre site. 

□ 

Syslog 

6,13 

Enregfetre les evements systemes cfens lesysbg. 


Figure 5-21 

Les modules standards de Drupal, de OpenID a Syslog 


Open ID : ce module permet de s’authentifier via OpenID. II sera aborde 
en detail dans le chapitre 12 « Ajouter des fonctionnalites ». Laissez-le 
desactive pour Tinstant. 

Path : ce module ajoute a Drupal la capacite de renommer les URL des 
conte nus pour les rendre plus agreables et faciles a lire. II doit etre active. 

PHP filter : ce module permet de saisir du code PHP dans certains con- 
tenus. II sera aborde dans le chapitre 7, section « Le format d entree 
PHP ». Laissez-le desactive. 

Ping : ce module permet de creer des reseaux de serveurs qui se notifient 
les uns les autres des nouveaux contenus present. 

Poll : permet la creation de questionnaires en ligne. 

Profile : ce module ajoute des champs supplementaires a la fiche d un uti- 
lisateur comme son site web, son adresse, etc. 

Search : un module tres important a activer, qui permet de proposer une 
recherche dans les contenus. 
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Statistics : ce module permet de compter les visites sur chacun de vos 
contenus. Les chiffres obtenus sont visibles sur un onglet Suii/i ajoute a 
chaque page de contenu. 

Syslog : il s'agit la de la version Unix du module Database logging. Nous 
l'etudierons de plus pres dans le chapitre 15, « Mettre son site en 

production ». 


Figure 5-22 

Les modules standards de Drupal, 
de Taxonomy a Upload 


0 

Taxonomy 

6.13 

Permet b cbssfbatbn du contenu. 

Req u is pa r : Fo ru m (d Eab led ) 

□ 

Throttle 

6.13 

Assure un mecanismed'autoiegulatbn permettantdecontrdler I'encombrementdu site. 

□ 

Tracker 

6.13 

Permet bsuivides dernieres contributions des utilisateuis. 

Depend de : Commenl (enabled) 

0 

Trigger 

6.13 

Permet □ des actions d'etre lances suite a certains evenements systemes, par esemple q 
contenu estcree. 

0 

Update 

status 

6.13 

Verifie In disponibilite de mises a jour de Drupal et de vos modules et themes installes. 

0 

Upload 

6.13 

Permet aux utilisateurs d'envoyer des fichiers et de bs attacher au contenu. 


Bon A SAVOIR Modules et dependances 

Les modules de Drupal peuvent dependre les uns 
des autres. Chaque module peut ainsi declarer de 
quels modules il est dependant, et sans lesquels il 
ne peut fonctionner. 

Si le module A depend du module B, Drupal affi- 
chera en dessous de la description du module A 
Depend de : A et sous la description du module 
B Requis par A. Si le module dependant ou 
requis n'est pas active, ce sera indique par (disa- 
bled) ou par (enabled) dans le cas contraire, et 
par (missing) s'il n'est pas installe. 

Si vous activez un module qui depend d'autres 
modules, Drupal vous proposera systematique- 
ment d'activer tous les modules dont votre module 
a besoin et qui ne le sont pas encore. En revanche, 
si votre module depend d'un module qui n'est pas 
installe, Drupal desactivera la case a cocher per- 
mettant de I'activer. 


Taxonomy : comme son nom l’indique, ce module est responsable de la 
gestion des taxons, du vocabulaire associe et de leurs interactions avec les 
contenus. 

Throttle : ce module permet de desactiver d'autres modules si la frequen- 
tation sur le site est trop forte. Nous etudierons ce module au 
chapitre 15, « Mettre son site en production ». 

Tracker : ce module permet de suivre les dernieres contributions (com- 
mentaires, contenus, etc.) sur le site. 

Trigger : le principe de ce module est de vous permettre de declencher des 
actions a partir d'evenements. Nous etudierons ce module en detail dans le 
chapitre 13, « Automatiser les taches recurrentes ». Pour l’heure, activez-le. 

Update status : nous ne presentons plus ce module qui doit evidement 
etre active. 

Upload : un module tres important qu'il convient d'activer afin de pou- 
voir aj outer des fichiers aux contenus (attachements). 


Telechargement d’un nouveau module 

Les modules disponibles en standard dans Drupal sont bien loin d'etre les 
seuls que vous pourrez utiliser. Pour notre premiere installation de modules, 
nous nous interesserons au module Administration menu. Ce module 
permet de simplifier enormement l'administration d'un site Drupal en 
dupliquant l'ensemble de la section Administration sous la forme d'un menu 
deroulant qui restera en permanence en haut de chaque page. 
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Si vous retournez sur la page par laquelle vous avez obtenu les sources de 
Drupal (http://drupal.org/project) mais en cliquant cette fois-ci sur le lien 
Modules, vous aurez une idee des possibility dans ce domaine. 


* Modules 

Contributed fcontrib) modules are plugins for Drupal that extend, build or enhance Drupal core functionality. Use matching versions (modules 
released for Drupal 5.x will not work for Drupal 6.x). Contributed modules are not part of Drupal core releases and may or may not have optimized 
code/functionality. If a module solves your needs please consider joining forces and helping the maintainer. 


Figure 5-23 La section de drupal.org dediee aux modules 


Chaque lien sur cette page mene a la page du projet dun module. Si 
nous nous deplafons vers Administration menu et que nous cliquons sur le 
titre, nous arrivons sur la page du projet de ce module, http://drupal.org/ 
project/admin_menu. 

Ces pages se composent toujours de la meme maniere avec tout d’abord 
un texte explicatif (en anglais), suivi des liens de telechargement des dif- 
ferentes versions, puis dune serie de ressources specifiques au projet 
(documentation, demonstration, anomalies, statistiques d usage, etc.). 

Lorsque vous cherchez a installer un module, choisissez de preference les 
liens de telechargement sur fond vert (stables) en accord avec la version 
de votre Drupal. Pour Administration menu , nous disposons de la version 
stable pour Drupal 6 : 6.X-7.3. En cliquant sur le lien Download , nous 
telechargeons un fichier tar.gz, le meme type d’archive que pour les 
sources de Drupal, que nous stockons pour l’instant sur le bureau. 


Bon A savoir Recherche 
des modules Drupal avec Google 

Une astuce bien pratique pour rechercher un 
module particulier consiste a utiliser la syntaxe 
avancee de Google. En effet, les URL des pages 
projet des modules Drupal ont toujours la meme 
structure, http://drupal.org/project/nom_projet. 
Pour trouver un projet qui traite du sujet « menu 
d'administration », il suffit done de taper dans la 
zone de recherche de google : 
site:drupal .org 

i nurl : project administration menu 


Choisir vos modules 

Avant de poursuivre, un avertissement : comme vous le voyez, la richesse 
des modules est un des grands atouts de Drupal. Mais elle presente aussi 
une certaine forme de danger consistant a les voir se multiplier dans 
votre systeme dans une joyeuse anarchie. 

Lorsque vous decidez d utiliser un module, surtout lorsque vous cons- 
truisez un site professionnel, sachez evaluer sa qualite en vous posant les 
bonnes questions. 

Ai-je vraiment besoin de ce module ? 

Lutilisation des modules n est pas sans consequence sur les performances. 
PHP est fait pour que chaque module active implique lmclusion de 
fichiers de code supplementaires, et ce, a chaque fois quune page est 
servie. Ce temps de chargement tend a se reduire au fur et a mesure des 
versions de Drupal mais reste neanmoins non negligeable. 
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Bonne PRATIQUE Faites le menage ! Lorsque Ton active un module, il est done important, a fortiori pour un 

; — ; — site a forte frequentation, de se poser la question de son utilite. 

Si vous ne cherchez qu a tester un module, pensez 1 11 

a noter son nom sur une liste a part de sorte a ne Dans le meme esprit, il existe souvent plusieurs modules pour la meme 

pas oublier de le supprimer plus tard. Ne laissez fonction, dont les champs d action sont plus ou moins etendus. Par 

jamais des modules inutilises installes et encore i i i t tT i , nn rnyr 

moins actives exemple, les modules filebrowser et WebrM permettent tout deux 

d’afficher des listes de fichiers a la maniere d’un service FTP. File- 
browser est cependant plus simple que WebFM qui lui est tres complet. 
Si vous n avez besoin que de permettre le telechargement de fichiers, 
Filebrowser sera done plus indique. 

Enfin, la force modulaire de Drupal tient autant a la profusion des modules 
disponibles qu au fait quil est tres simple de realiser ses propres modules, 
ou encore de simplifier des modules existants. Cette possibility est totale- 
ment accessible a qui possede des competences basiques en PHP 1 . 

Dans notre exemple, nous allons chercher a installer le module Admi- 
nistration menu dont le but sera de simplifier enormement l’administra- 
tion d un site Drupal. Le besoin est d’autant plus justifie qu une fois 
active, ce module sera charge uniquement pour l’administrateur du site. 

Ce module est-il stable ? 

Une fois que votre choix s’est porte sur un module vient la question de sa 
stability. Tous les modules fournis pour Drupal sont foeuvre de gens 
comme vous et moi qui ne passent pas 100 % de leur temps sur ce travail. 
Il convient done de prendre cet aspect en compte pour n avoir que les 
avantages de ces developpements libres, sans les inconvenients. 

Ne mettez ainsi jamais sur un site un module en developpement (liens 
sur fond rouge) ou en version RC ou Alpha. Meme si Ton peut transiger 
sur la seconde categoric, ces modules ne sont, par definition, pas stables 
et ne doivent en aucun cas finir sur un serveur de production. 

Les modules Drupal suivent un nommage de version uniformise. Une 
version 6.X'2.0-de v indique un module concpa pour Drupal 6, ayant pour 
version 2.0, et qui est en phase de developpement. 

Ce module survivra-t-il ? 

Comme nous favons vu dans la description generate de Drupal, les 
modules ne beneficient jamais d’une compatibility ascendante. Un 
module ecrit pour une version 6 de Drupal ne fonctionnera pas en l’etat 
dans la version 7. Chaque changement de version implique pour les 
developpeurs des modules un travail de « portage » de leur oeuvre dans la 
version superieure. Or, si le module est peu soutenu par une commu- 



1. Un tutoriel pour fabriquer ses propres modules : http://www.arnumeral.fr/node/14 
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naute dutilisateurs, il sera peut-etre abandonne par son auteur, vous 
obligeant alors a faire ou a faire faire ce portage s’il s’agit dune fonction 
trop ancree sur votre site pour etre remplacee. 

Pour evaluer au mieux l’avenir dun module, il est done important d’etu- 
dier l’ecosysteme qui gravite autour, a commencer par ses utilisateurs. 
Pour vous aider dans cette etude, deux outils se trouvent sur la page d un 
module : les anomalies et les statistiques d utilisation. 

Les anomalies sont disponibles via le lien View all issues dans la page de 
projet dun module. Elle vous permettent de voir le niveau d’activite sur 
le module. Si les dernieres anomalies non corrigees datent de plus d un 
an, e’est tres mauvais signe. 


Issues for Administration menu 

Create a new issue Advanced search Statistics Subscribe 

Search for Status Priority Category Version 

| | - Any - l| | - Any - j | - Any - j | - Any - j 

Component 

I " An y " 3 | Search | 


Summary 

Status 

Priority 

Category 

Version Component 

Replies 

Last updated Assigned to 

IE7: Offset between browser 
viewport and menu in themes with 
body { position: relative > updated 

needs 

work 

normal 

bug reports 

_ „ , CSS / Browser 

6.x- 3.x- dev „ 

Support 

28 

6 new 

1 day 3 hours 

Allow dynamic replacements in 
the menu new 

fixed 

normal 

tasks 

6.x-3.x-dev Code 

5 

5 new 

1 day 5 hours 


Figure 5-24 Liste des anomalies remontees par les utilisateurs pour le module Administration menu 


Dans l’exemple en copie d’ecran, nous avons les anomalies du module 
Administration menu, et nous constatons que la derniere correction date 
de moins de deux jours, ce qui est tres bon signe. 

Les statistiques d utilisation permettent quant a elles de se faire une idee 
du nombre de sites utilisant ce module a travers le monde. Pour y acceder, 
dans la page de projet du module, cliquez sur le lien View usage statistics. 


Weekly project usage 

Weekly Administration menu usage by API version 



■ 5.x 

■ 6.x 

■ 7.x 

■ TotaJ 


Figure 5-25 

Statistiques d'utilisation 
du module Administration menu 
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Bon a savoir La source d'Update status 

Pour ceux qui se demanderaient d'ou viennent ces 
chiffres, il s'agit tout simplement d'informations 
indirectement donnees par le module Update 
status que nous venons d'activer. En effet, le role 
de ce module est de verifier que tous les modules 
actives sont a jour et ne presentent pas de failles 
de securite. Pour arriver a ses fins, il doit done se 
connecter sur le site drupal.org pour comparer les 
numeros de version. Le site dispose ainsi de statis- 
tiques precises des modules actives. 


Bonne pratique Une place pour chaque chose 

Nous ne le repeterons jamais assez, le seul endroit 
ou vous devez installer vos modules (mais aussi, 
nous le verrons, vos themes) est le dossier si tes. 
N'installez jamais quoi que ce soit hors de ce dos- 
sier. Pour bien comprendre ce principe, vous devez 
pouvoir a tout moment decompresser une nouvelle 
version de Drupal et y deplacer le dossier si tes 
pour que tout fonctionne a nouveau comme avant. 


Ici, nous voyons que lutilisation de la version pour Drupal 6 de ce 
module est en constante hausse ce qui, la aussi, est un bon signe. 

Installer un module 

L’installation de Tarchive tar.gz dun module est pour l’heure une ope- 
ration manuelle assez similaire a Installation de Drupal que nous avons 
effectuee. Il s’agira simplement de decompresser l’archive a un endroit 
precis de l’arborescence. 

Comme nous l’avons vu dans la section « Comprendre la structure des 
dossiers » au chapitre precedent, les modules lies a installation de 
Drupal sont places dans le dossier modul es. Il ne faut done en aucun cas 
ajouter a cet endroit vos propres modules. Cela fonctionnerait, mais vous 
poserait aussi beaucoup de problemes au moment des mises a jour de 
votre installation quand vous devrez faire le tri entre vos modules et ceux 
de Drupal. 

La bonne place pour mettre des modules est le dossier sites. Dans ce 
dossier, vous avez pour l’heure deux sous-dossiers all et default. C’est 
dans le sous-dossier all que devront etre copies tous les nouveaux 
modules que vous desirez ajouter a Drupal. 

Quels que soient l’arborescence et le nombre de sous-dossiers que vous 
ajouterez dans ce dossier, Drupal retrouvera votre module. Ce nest 
cependant pas une raison pour manquer d’organisation. La bonne pra- 
tique consiste a creer d’abord un sous-dossier nomme modules qui con- 
tiendra tous les modules que vous utiliserez. Peut-etre realiserez-vous 
dans l’avenir des modules personnels, qui cohabiteront avec d’autres 
venant de drupal.org. Pour eviter toute confusion, anticipons cette possibi- 
lity et creons encore deux sous-dossiers, mes_modules et contrib. 

Il ne nous reste maintenant plus qua decompresser l’archive 
admi n_menu_6 . x-1. 3 . tar .gz dans le dossier sites/all /modules/ 
contri b, donnant lieu a un nouveau sous-dossier admi n_menu. 


Bon A SAVOIR wget pour une installation instantanee 

Pour les unixiens, un moyen tres simple d'installer un module Drupal consiste a utiliser la 
commande wget. II suffit pour cela de copier I'adresse du lien de telechargement dans la 
page de projet du module et de la recopier comme suit dans un terminal : 
mkdi r -p sites/all /modul es/cont rib 
cd sites/all /modul es/cont rib 

wget -qO - http://ftp.drupal.org/files/projects/admin_rnenu-6.x- 
1.3. tar.gz | tar -zxvf - 

La commande wget lit I'archive a travers I'lnternet et en restitue le contenu dans la sortie 
standard. La commande tar lit cette sortie et effectue la decompression a la volee. Le 
resultat sera un module installe directement sans fichiers temporaires. 
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La mise en place de notre module etant faite, retournons a present dans 
radministration des modules pour y trouver Administration menu. Nous 
remarquons au passage l’apparition dune nouvelle categorie Administration. 

II ne reste alors qua cocher son activation, sans oublier de cliquer ensuite 
sur Enregistrer la configuration. 

“ Administration ld 


Active Nom 


Version Description 


0 


Administration 

menu 


G.a-1 .5 


Fournit un menu deroulant pour les taches 
administratives les plus courantes, et pour 
d'autres destinations usuelles (pour les 
utilisateurs possedant les permissions 
appnopriees). 


Figure 5-26 

Activation du module Administration menu 
dans le panneau cTadministration des modules 


Une fois le module active, vous devriez voir apparaitre en haut de la page 
un nouveau menu deroulant regroupant l’ensemble de Tadministration 
de Drupal. Oil que vous soyez, vous pourrez done utiliser ce menu pour 
parametrer votre site. 


a-.. Construction du site 

Gestion du contenu Configuration du site Gestio 



Menus 

ffl | 

Modules 

© Desinstaller 

1 Themes 

© Liste 

Traduction de I'interface 

III | 

1 Accueil * Administrer • C 


Figure 5-27 

Le module Administration 
menu en action 


Bon Asavoir Reorganiser vos modules 

Si par hasard vous avez besoin de reorganiser vos 
modules dans differents dossiers, il se peut que 
Drupal n'apprecie pas cette action et que vous 
aboutissiez sur une page blanche. Pas de panique, 
la procedure de mise a jour que nous aborderons 
un peu plus loin est capable de regler le probleme. 
II suffira de la lancer jusqu'au bout pour que votre 
site soit a nouveau fonctionnel. 


Desinstaller un module 

Lorsquun module est decompresse a partir de son archive puis active, il 
va potentiellement creer des tables dans la base de donnees, des variables 
dans le systeme Drupal, etc. Il est done hors de question pour le desins- 
taller de simplement detruire le dossier d un module. 

Vous devez avant toute chose retourner dans radministration des 
modules pour desactiver le module que vous desirez supprimer. Ceci fait, 
en haut de la page, vous trouverez un onglet Desinstaller. Il faut com- 
prendre ici « Desinstaller les donnees installees par le module ». Cette 
option ne detruira en aucun cas des fichiers. 

Sur cette nouvelle page, vous retrouverez la liste des modules qui ont ete 
desactives et en attente dune possible desinstallation. Cochez les 
modules que vous souhaitez supprimer et cliquez sur Desinstaller. 
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Le processus de desinstallation supprime I'ensemble des don nee s Ness a un modLile. Pour desinstaller 
un module, vous devez d'aboid le des active r, Les modules ne supports nt pas tons cette fonctionnalite. 


Figure 5-28 

Liste des modules susceptibles 
d'etre desinstalles 


Des installer Norn Description 


0 IMCE An image/file upbader and browsor supporting personal directories and user quota. 

1 0 j Wys rwyg Allows users to edit contents with c lient-s ide editois . 


| Desinstaller | 


Drupal vous renvoie alors sur une page de confirmation oil vous pouvez 
encore Annuler ou confirmer faction de Desinstaller. Ceci fait, vous 
pourrez supprimer physiquement le dossier du module. 

Soumettre une anomalie 

Comme Drupal lui-meme, les modules sont des logiciels libres developpes 
par des gens comme vous et moi. Chacun peut participer a famelioration 
de fensemble et ainsi faire avancer la communaute. II peut s’agir de code 
bien sur, mais aussi de traduction ou encore plus simplement de prendre la 
peine de signaler une erreur de fonctionnement a f auteur d un module. 
Vous serez alors surpris de la vitesse de reaction de certains auteurs qui ne 
mettront que quelques jours a corriger une anomalie. 

Pour declarer une anomalie, il vous faudra tout d’abord creer un compte 
sur Drupal.org. Cela se fait tout simplement en cliquant sur le lien Create 
new account dans la boite User I du site. 
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Figure 5-29 

Creer un compte sur drupal.org 



Une fois vos identifiants re<pis, il suffit d’aller sur la page de projet du 
module et de cliquer sur View all issues pour declarer fanomalie. Si votre 
anomalie n a pas encore ete trouvee (ce que vous pouvez verifier en fai- 
sant des recherches), cliquez sur le lien Create a new issue et decrivez 
aussi precisement que possible le probleme rencontre sans oublier de 
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specifier la version du module, le type d’anomalie (critique, mineur, etc.) 
et de laisser le statut a active. Plus vous serez precis dans la description, 
plus l’auteur pourra resoudre rapidement votre probleme. 
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-Project information 

Project: Version: * Component: * 

Administration menu | 6iX _i i3 J [code 

LO 

.-Issue information 

Category: * Priority: Assigned: Status: 

| bug report | minor [unassigned jJ | active *\ 

Descriptions of the Priority and Status values can be found in the Issue queue handbook 

-Issue details 

Title: * 

II I 

Description: * 


Figure 5-30 Saisir une nouvelle anomalie 

Une fois validee, votre anomalie apparaitra dans la liste View all issues. 
Vous pourrez alors revenir plus tard pour prendre connaissance des 
reponses donnees. 


Le parametrage general de Drupal 

Comme nous l’avons vu, chaque module a son role a jouer dans l’admi- 
nistration de Drupal. II est done grand temps de faire un tour dans la 
configuration du site pour regler toutes les fonctionnalites qui sont 
maintenant activees. 

Comme nous Favons vu au debut de ce chapitre, tout ce qui touche a la 
configuration de Drupal se trouve dans la section Configuration du site. 
Cliquons sur ce lien pour parcourir ensemble les principaux reglages qui 
nous sont offerts. 

Bolte a outils image 


La boTte a outils GD2 est installee etfonctionne correctement. 

Qualite JPEG : 

1 7 5 | % 

Definir la qualite d' image pour les co nve rsio ns e n JPEG, sur une echelle de 0 a 100. 


Figure 5-31 

Reglage de la qualite des images JPEG 


Dans cette section, vous pouvez regler la qualite de compression des 
images qui sera appliquee par le processeur damages de Drupal. Ce der- 
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nier peut utiliser la bibliotheque php-GD2 (conseille) ou php-imagick. Un 
message vous indique au debut de la page quel systeme est active ou vous 
avertit le cas echeant qu’aucun systeme n a ete installe. 

Lorsque vous avez termine le parametrage, vous pouvez cliquer sur le 
bouton Enregistrer la configuration. 

Date et Heure 

Cette section s’occupe de tout ce qui touche a la gestion du temps dans 
Drupal. Cela commence par le choix du fuseau horaire. Pour regler ce 
champ, faites correspondre Tune des heures donnees dans la liste derou- 
lante avec l’heure reelle. 


Langues et parametnes negionaux 


Figure 5-32 

Reglage du fuseau horaire 


Fuseau horaire pardefaut : 

| mencredi, 8 juillet2009 - 1 :35am +0200 0 j 

Choisissez le fuseau horHire par defaut du bHb. 

Fuseaux horaires personnalisables : 

Desactive 

Active 

Si active, lea util^teuia peuvent definir leurpropia fuseaux horaire 

Premier jour de b semaine : 

| lundi C ] 

Le p ne m ie r jo u r de la se maine . po u r lea vuea de type cale nd rie r. 


Vous pouvez en outre activer les fuseaux personnalisables qui permet- 
tront a vos utilisateurs de choisir leur propre fuseau horaire a travers la 
configuration de leur profil. 

Enfin, vous devez definir dans la liste deroulante suivante le premier jour 
de la semaine qui servira pour les vues de type « calendrier ». II s’agit 
generalement de selectionner « lundi ». 


Figure 5-33 

Choix des formats pour les dates 


Formats 

Format court des dates : 


| 08/07/2009 - 01 :37 

1 = ] 

Le format court d'affic hage des dates et heures. 

Format moyen des dates : 

| 8 juillet £009 - 1:37am 

Is 


Le format moyen d'affbhage des dates el heures. 

Format long des dates : 

mencredi, 3 juillet 2009 - 1 :37am 0 j 


Le fo rma t d'affic hage des dates et heures le plus dels ills 
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Ensuite vient le format d’affichage des dates selon les besoins : court 
(date numerique et heure), moyen (jour en clair, date numerique et 
heure) et long (jour et mois en clair, annee et heure). Nous allons choisir 
un format francise avec le jour qui precede le mois. 

Lorsque vous avez termine le parametrage, vous pouvez appuyer sur le 
bouton Enregistrer la configuration. 

LO 

Informations 


Informations 

Nom : 


[Colchique 


La nom de ce sits. 


Adresse electronique : 


[webmaster@colchique-conseil.fr 


Le champ De des emaib auto matiq use envois pendant la procedure d'e n rag iatra me nt, fesdemandea 
les autres notificationB. 


Slogan: 


[Carchaque brin d'herbe est unique.. 


La devise de voire arte, slogan, ou une phrase accrocheuse (so uve nt aff ic hee a cote du litre du srtej. 


Figure 5-34 

Nous retrouvons ici les informations saisies lors de Installation. 


Dans cette section, vous retrouverez une partie des elements que nous 
avons definis lors de Installation : 

• Nom du site : normalement vous devez y retrouver « Colchique » ; 

• Slogan du site : une devise ou une accroche qui pourra apparaitre au 
cote du titre du site dans l’en-tete. Pour l’exemple, saisissez ici une 
devise comme « Car chaque brin d’herbe est unique... » ; 

• Objectifs du site : qui apparaitront en haut de la page d’accueil. II est 
possible d’utiliser ici la syntaxe XHTML. Laissons ce champ vide 
pour nos tests ; 

• Pied de page du site : qui apparaitra a la fin de chacune des pages. La 
aussi, la syntaxe XHTML est autorisee. Nous allons utiliser un 
meilleur moyen pour gerer les pieds de page, laissons done ce champ 
vide lui aussi ; 

• Nom de I'utilisateur anonyme : cet identifiant sera le nom officiel des 
utilisateurs qui ne sont pas connus du systeme. II sera utilise 
lorsqu’un visiteur commentera un billet sans donner son nom ; 

• Page de garde par defaut : Ce champ est tres important car il deter- 
mine ce que la page d’accueil contiendra. La valeur node indique a 
Drupal que la page d’accueil presentera une liste de contenus (appeles 
des noeuds, ou nodes, en langage Drupalien) classes du plus recent au 
plus ancien. Vous pouvez cependant changer cette valeur pour 
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n importe quelle reference (URL) a un contenu que vous aurez cree, 
comme nous le verrons un peu plus loin. 

Lorsque vous aurez termine le parametrage, vous pourrez cliquer sur le 
bouton Enregistrer la configuration. 

Journalisation et alertes 

Par defaut, Drupal stocke dans la base de donnees toutes les erreurs 
detectees par les modules ainsi qu un grand nombre d ’informations liees 
a la vie du site (ajout de commentaires, de contenus, authentification 
d’utilisateurs, etc.). Ces messages sont disponibles dans la section Rap- 
ports de l’administration, par le lien Entrees recentes du journal. 


Journalisation en base de donnees 

Supprimer les entrees du journal au deb de cette ligne : 

Figure 5-35 

Reglage du nombre d'enregistrements 

danS le journal aubomatiquemenlsupprimeee (Necassrte une con Figure rion co nee te des laches de maintenance cron.) 


| 1 000 C | 

Le no mb ib maximum de lig nes a go nse rve r da ns le journal. Les a nc ie n nes e ntr^es as ro nt 


Comme ces donnees peuvent a terme prendre un volume tres important 
dans la base, il est important d’en limiter le nombre. Pour regler cette 
valeur, cliquez sur le lien Database logging. La liste deroulante qui appa- 
rait indique que le nombre de messages conserves est de 1 000 . La 
vidange des donnees supplementaires est effectue par le cron de Drupal 
que nous allons etudier un peu plus loin. 

Rapports d’erreur 

Laissons pour le moment les deux premiers champs que nous utiliserons 
plus loin dans notre projet pour nous interesser a la liste deroulante Rap- 
ports d'erreur. Cette liste va nous permettre de determiner si Drupal doit 
afficher les erreurs PHP a l’ecran ou seulement les consigner dans le 
journal des erreurs. 


Figure 5-36 

Parametrage des rapports d'erreur 
pour une plate-forme de developpement 


Rapports d'erreur : 

| I n sc ri re les erreurs dans le journal et les afficher a Hecran 0 | 

Specif ie oil leseneursde Drupal, PHP, et SQL sont consignees. Surunserveurde production, ilest 
lecommande que les eneuis soient uniquement inscrites dans le jo u mal des e ne u is. Surunserveurde 
test, il peut etre utile a la foe de les inscrire et de les afficher a fecian. 


86 


Le premier cas est surtout utile pendant la phase de developpement de 
notre site oil nous apprecierons d’avoir un retour visuel des erreurs que 
nous aurions commises. En revanche, il est necessaire de positionner 
cette valeur dans le mode Journal d'erreur seulement si vous parametrez 
votre site de production. 
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Une fois le parametrage termine, n oubliez pas d’appuyer sur le bouton 
Enregistrer la configuration. 

Transfert de fichiers 

Le transfert de fichiers est gere par le module Upload que nous avons 
active. II est necessaire a Tattachement de fichiers aux contenus. 

Nous le verrons plus loin dans ce livre, les documents attaches a un con- 
tenu peuvent etre affiches sous la forme d une liste ou etre invisibles. Le 
champ Liste les fichiers par defaut nous permet de determiner lequel des 
deux modes est active par defaut. Cela n empechera pas lutilisateur de 
changer cela au cas par cas. 

Ensuite, nous allons pouvoir imposer un certain nombre de limites aux 
fichiers qui pourront etre envoyes sur le serveur. S’il s’agit d’une image, 
nous pouvons definir une dimension maximale. Si cette dimension est 
depassee, l’image sera automatiquement redimensionnee. Par defaut, la 
dimension est de 0 et signifie quaucune limite n est appliquee. 


Resolution maximale des images transferees : 

j 1280x1 024| ] Largeur x Hauteur 

La taille maximale autorisee pour les images tiansmbes ijDa r e tie mp le 640x480) ou "0" pour 
indiqueraucune iBetrfattan. Si une boibe a outil image est inslallee les Fic h is rs q u i depasse n t ce tbe 
taille seiont isdimensionnes. 


Figure 5-37 

Toute image de plus de 1280 x 1024 pixels 
sera automatiquement redimensionnee. 


Nous pouvons aussi imposer une contrainte de taille pour chaque fichier 
(par defaut, 1 megaoctet) ou pour un utilisateur (par defaut, 1 mega- 
octet ici aussi). Tout depassement entrainera le refus du telechargement. 
Attention cependant, pour la taille maximale d un fichier de ne pas 
depasser la taille maximale autorisee par votre configuration de PHP (ici 
8 megaoctets). Si vous avez besoin de plus, changez cette valeur dans 
votre fichier php . i ni et redemarrez ensuite le service Apache. 


{Par defaut) Taille maximale de chaque fichier : 

[s | Mo 

Laiaille masimale que peut avoir un f ic h ie r transfe is parun utilisateur. Si une image est 
transfeise etqu'une issolution masiimale est position nee, la taille se la co ntrb lee apissque le 
f ich ie r art ete led ime nsio n ne . 


Figure 5-38 

Augmentation a 8 et 10 Mo des tailles limites 


(Par defaut) Taille totale des fichiers par utilisateur : 

[l 0 | Mo 

(Pardefaut) La taille maximale de tous les fchiers qu'un utilisate ur peut place r sur le site. 
Vos parametnes de PHP limite nt la taille maximale de chaque transfert a 8 Mo. 


II nous est possible de definir une liste d’extensions autorisees nous per- 
mettant d’eviter des formats de fichiers qui ne nous conviendraient pas. 
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Figure 5-39 

Liste des extensions autorisees 


Figure 5-40 

Dossier temporaire utilise par Drupal 


Figure 5-41 

Dossier de stockage des fichiers attaches 


Bon a savoir Deplacer le dossier 
des fichiers attaches 

Les fichiers attaches sont references dans la table 
Fi 1 es de la base de donnees. Si vous etes dans 
la necessity de deplacer le dossiers des fichiers, 
vous avez toujours la possibility de corriger les 
chemins contenus dans la colonne filepath de 
cette table. 
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(Pardefaut) Extensions nutorisees : 

[jpg jpeg gif png txt pdf odt ods odp 

(Par defaut) Les exte nsio ns q ue les utilisate u rs pe uve nt transfe re r. Separez les exte nsio ns avec 
un espace et n’incluez pas le point en d£but (ex : .pdf => pdf). 


Bonne pratique Les formats ouverts 

Lorsque vous attachez un document a un contenu, pensez toujours a I'utilisateur final et si ce 
dernier a la capacite ou non de le lire. 

A ce titre, evitez autant que possible les formats proprietaires qui ne seront lisibles que des 
personnes disposant des licences adequates. Pour des documents non modifiables, vous 
pouvez utiliser facilement le format PDF, lisible par tous et sur toutes les plates-formes. Pour 
des documents bureautiques, le format ouvert OpenDocument est pris en charge par de nom- 
breux logiciels gratuits comme OpenOffice.org (http://www.openoffice.org). 


Systeme de fichiers 

Drupal a besoin de deux emplacements pour stocker ses fichiers. Le pre- 
mier emplacement correspond aux fichiers qui sont attaches a des con- 
tenus par le module Upload, le second a des fichiers temporaires qui 
n ont pas vocation a etre conserves. 


Repertoire temporaire : 

|/var/tmp | 

Che min du dossier dans lequel les fichierE telecharges pounont etre stockes d u rant lea p re-VEualEatio ns. 


Par defaut, Drupal parametre le dossier temporaire de maniere a utiliser 
le dossier temporaire de votre systeme d’exploitation, ici /var/tmp (ou 
/tmp) pour un systeme Unix ; nous pouvons done le laisser ainsi sans trop 
de problemes. 


O lie m in du doss ie r de stoc kage : 

site/default/files 


S’agissant des fichiers attaches aux contenus, il est important que vous 
choisissiez un dossier que vous sauvegarderez regulierement. La norme 
Drupal veut que ces fichiers soient stockes par defaut dans le dossier 
sites/default/files sous sa racine, mais rien ne vous empeche de les 
placer ailleurs. Gardez cependant a fesprit qua chaque fois qu un fichier 
est attache a un contenu, Drupal stocke en base de donnees le chemin 
exact de ce dernier. Si vous changez ce dossier en cours de route, 
r ensemble des fichiers precedemment attaches deviendront inaccessibles. 
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Dans cette page, il est aussi possible de regler la Methode de telecharge - 
ment des fichiers. Le choix entre l’option Privee et l’option Publique 
depend de deux criteres : 

• dans le mode public, c’est le service Apache qui va etre charge 
d’envoyer les fichiers au navigateur. Le dossier doit done dans ce cas 
etre sous la racine de Drupal, ce qui est le cas par defaut. 

• dans le mode prive, c’est Drupal qui envoie les fichiers au navigateur. 

Le dossier peut done etre n importe oil sur le disque. 

De plus, en mode prive, Drupal gere les autorisations de telecharge- 
ment, alors quen mode public, Apache autorise par defaut tous les 
fichiers a etre telecharges. C’est d’ailleurs ce dernier point qui vous 
permet de choisir fun des deux modes. Si vous souhaitez attacher a vos 
contenus des fichiers confidentiels, vous devez choisir le mode Prive. Au 
contraire, si vous n avez que des fichiers qui sont de toute fa^on accessi- 
bles a tous, prenez foption Publique , qui presente l’avantage de con- 
sommer moins de ressources. 

Dans un cas comme dans l’autre, il faut que le service Apache ait les 
droits d’ecriture sur ce dossier. 


En resume 

• L administration de Drupal est certes complexe, mais elle est ration- 
nelle. En peu de temps, vous acquerrez les bons reflexes qui vous per- 
mettront de vous y reperer. 

• L’ensemble des fonctions fondamentales de Drupal est issu des 
modules fournis en standard. 

• Il est possible d’etendre les fonctionnalites de Drupal a faide de nou- 
veaux modules que vous pouvez telecharger sur drupal.org. 

• Drupal est un outil communautaire qui a besoin de votre aide. 
Lorsque vous trouvez une erreur dans le coeur de Drupal ou dans fun 
de ses modules, nhesitez jamais a signaler fanomalie. 

• Si vous butez sur un probleme concernant un module, ou si vous 
n arrivez pas a identifier le module correspondant a votre besoin, vous 
pouvez poser une question sur le forum http://drupalfr.org/forum, dans la 
section Support general. 
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Gerer les utilisateurs 


Les utilisateurs sont un element fondamental de tout CMS. 
Ce sont eux qui produisent des contenus, seuls ou a plusieurs ; 
ce sont aussi eux qui commentent les contenus et les font vivre. 
II est alors logique sous Drupal d’accorder aux utilisateurs un 
statut specifique, associe a un mode de gestion 
particulierement pousse couvrant de multiples dimensions. 


SOMMAIRE 

► Comprendre le systeme 
de droits de Drupal 

► Parameter les comptes 
utilisateur 

► Gerer les nouveaux utilisateurs 
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Culture 

L'origine du concept role/permission 

Le systeme de droit de Drupal est issu d'un modele 
datant de 2003 appele OrBAC ( Organization 
Based Access Control, en frangais Controle 
d'acces base sur I'organisation) qui introduit un 
sous-modele appele R-BAC (Role-Based Acces 
Control, en frangais Controle d'acces a base de 
roles) ou les utilisateurs exergant des fonctions simi- 
laires sont regroupes sous un meme role auquel est 
associe, par une autorite superieure, une serie 
d'autorisations d'acces (nos permissions Drupal). 


Roles, permissions et utilisateurs 

Le systeme de droits de Drupal est fonde sur une combinaison permis- 
sions/roles et roles/utilisateurs. 

• Une permission est un droit simple portant sur une operation de 
Drupal, par exemple « Creer un nouvel article ». 

• Un role est quant a lui un ensemble donne de permissions. 

• Un utilisateur est la maniere dont Drupal voit une personne qui visite 
le site. A cet utilisateur est associe un ou plusieurs roles. 

Par defaut, Drupal definit trois roles fondamentaux : 

• le role Administrates, qui est associe a un seul utilisateur qu on 
appelle done l’administrateur ; 

• le role Utilisateur identifie, qui est associe automatiquement a tout 
utilisateur qui est connu de Drupal, e’est-a-dire qui dispose sur le site 
dun compte utilisateur et qui a en consequence saisi un identifiant et 
un mot de passe ; 

• le role Utilisateur anonyme, qui est associe automatiquement a un 
visiteur. A noter que si une personne possedant un compte sur le site 
ne saisit pas son identifiant et son mot de passe, Drupal le considere 
comme Utilisateur anonyme. 

Venant seulement d ’installer notre Drupal, un seul utilisateur est pour le 
moment connu du systeme : e’est l’administrateur. 

L’administrateur est l’utilisateur ayant le plus de pouvoir sur le systeme 
Drupal. Un peu a la maniere de l’utilisateur root sur un systeme Unix, 
rien n’est interdit a 1’administrateur. II n’est en consequence pas tres avise 
de travailler en permanence avec ce role. Parce qu’il possede les droits les 
plus etendus, vous risquez de biaiser votre developpement en croyant que 
certaines actions sont possibles, ou certaines pages accessibles, alors 
qu’elle ne le sont pas pour un simple visiteur. 

C’est done une bonne idee pour la qualite de notre projet que de devenir 
schizophrene en creant trois identites distinctes que l’on endossera tour 
a tour, et selon les taches a effectuer : 

• administrates : en saisissant l’identifiant et le mot de passe adminis- 
trates que nous avons choisi lors de Installation ; 

• visiteur : pour cela, il nous suffira de nous deconnecter ; 

• Marine : une utilisatrice que nous allons creer qui disposera automa- 
tiquement du role Utilisateur identifie mais aussi d’un nouveau role 
Contributes que nous allons aussi creer. Ce role sera dote de toutes 
les permissions lui permettant de creer des contenus. 
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Dans la suite de ce livre, nous basculerons done tour a tour sur Tun de 
ces roles selon que nous travaillerons sur la structure du site (utilisateur 
administrates), sur le contenu du site (utilisateur contributeur) ou sur 
l’utilisation du site (utilisateur visiteur). vo 


Creer vos propres roles 

La premiere phase de la gestion des droits consiste done a definir les 
roles qui nous seront necessaires pour notre site. Dans cet ouvrage, nous 
nous limiterons aux trois types dutilisateurs evoques plus haut : admi- 
nistrates, contributeur et visiteur. 

Le role d utilisateur identifie correspond a un role pris par nimporte quel 
utilisateur s’etant prealablement identifie sur notre systeme - e’est-a-dire 
ayant saisi un identifiant et un mot de passe - a la difference de Y utilisateur 
anonyme. Un utilisateur ayant le role Contributeur ou Administrateur 
possede done de maniere implicite le role Utilisateur identifie. 

Pour creer notre role Contributeur, nous devons aller dans le menu 
Administrateur , puis cliquer sur Administrer , Gestion des utilisateurs , puis 
enfin sur Roles. 


Nom 

utilisateur anonyme 
utilisateur identifie 


[contributeur] 


Operations 

ve rro u i I le mod if ie r le s d no its d 'acce s 

ve rro u i I le mod if ie r le s d no its d 'acce s 

| Ajouter un role | 


Figure 6-1 

Ajout d'un nouveau role Contributeur 


Nous retrouvons ici installes par defaut deux des roles que nous venons 
d’evoquer : utilisateur anonyme et identifie. Le role Administrateur est 
quant a lui absent car, possedant par definition tous les droits, il n est pas 
necessaire de le faire apparaitre. 

Nous allons done saisir le nom de notre nouveau role, contributeur, et 
appuyer sur le bouton Ajouter un role. 


Gerer les permissions par role 

Disposant maintenant des roles Utilisateur anonyme et Contributeur, il 
nous faut definir les permissions qui leur sont associees. Pour ce faire, 
vous pouvez soit cliquer simplement sur le lien modifier les droits d'acces a 
cote du role correspondant, soit retourner dans le menu Administrateur , 
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puis Gestion des utilisateurs , et enfin Droits d'acces. La seule difference 
entre ces deux approches est que la seconde va nous permettre de modi- 



fier les droits pour l’ensemble des roles 

sur une seule et 

meme page. 

Droit d'acces 

utilisate ur a nonry me 

utilisate ur identifie 

contributeur 

module block 




administrer les blocs 

□ 

□ 

□ 

utiliser PHP pour la visibilite des blocs 

□ 

□ 

□ 

module comment 

acceder au* commentaires 

□ 


□ 

administrer les commentaires 

□ 

□ 

□ 

soumettre des commentaires 

p 

tad 

□ 

soumettre des commentaires sans approbation 

pi 

lad 

□ 


Bon A savoir Comment creer tres 
simplement un site prive 

Si vous cherchez a creer un site accessible unique- 
ment aux utilisateurs identifies, il faut absolument 
qu'aucune case ne soit cochee dans la colonne de 
I'utilisateur anonyme. De cette maniere, la seule 
chose que verra I'utilisateur anonyme en arrivant 
sur votre site sera un message d'erreur « Vous 
n'etes pas autorise a acceder a cette page » et une 
boTte de saisie pour un nom d'utilisateur et un mot 
de passe. Si le visiteur dispose d'un compte, il 
devra se connecter pour voir le contenu, sinon, ce 
contenu restera prive. Cela represente une securite 
raisonnable. 


Figure 6-2 Gestion des permissions 

Chaque ligne de cette nouvelle page correspond a une permission, un 
droit d'acces. Comme vous le voyez, chaque module propose ses propres 
permissions, ce qui implique une granularite des autorisations rarement 
egalee dans le monde des CMS. 

Le role Contributeur aura pour caracteristique de pouvoir, comme le 
role Administrates, creer un article. Les articles et les contenus sont 
pris en charge par le module Node. En se deph^ant jusqu a cette section, 
nous decouvrons qu’il est possible de regler a peu pres tous les aspects de 
la creation de contenu. Nous concernant, nous allons cocher acceder au 
contenu pour tous les roles car tout le monde aura le droit de voir les arti- 
cles, y compris les anonymes. En revanche, nous cochons create story 
content (creer un article) pour le seul role Contributeur. 

Voyons maintenant plus precisement, module par module, quelles per- 
missions nous devons affecter a tel ou tel role. 


94 


Permission du module Comment 

Ce module est dedie a la gestion des commentaires. Nous avons besoin 
d’affecter les droits suivants. 

• Acceder aux commentaires : pour permettre a tous les utilisateurs iden- 
tifies ou non de voir les commentaires. 

• Soumettre des commentaires et Soumettre des commentaires sans 
approbation : pour permettre a tous les utilisateurs identifies ou non 
d ecrire des commentaires. Le second droit, quant a lui, permet a l’uti- 
lisateur de publier directement ces commentaires, sans etre modere. 
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Droit d'acces 


utilisateur utilisateur 

anonyme identifie 


module comment 


acceder aux commentaires 

0 

0 

□ 

administner les commentaires 

□ 

□ 

□ 

soumettre des commentaires 

0 

0 

□ 

soumettre des commentaines sans 

approbation 

111 

0 
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Figure 6-3 

Les permissions a activer pour le module Comment 
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Notez que nous ne donnons ces droits qu au role Utilisateur identifie et 
pas au role Contributeur. En effet, un utilisateur ayant le role Contribu- 
teur aura aussi automatiquement le role Utilisateur identifie. Comme nous 
cherchons a ce que tous les utilisateurs puissent deposer des commentaires, 
cocher cette permission pour Contributeur n apporterait rien de plus. 

Permissions du module Node 

Le module Node est, comme nous venons de le voir, charge de la gestion 
des contenus. Dans cette section, nous allons donner les droits suivants. 

• Acceder au contenu : comme pour les commentaires, tous les utilisa- 
teurs, identifies ou non, peuvent lire les contenus. 


Droit d'acces 

utilisateur 

anonyme 

utilisateur 

identifie 

contributeur 

Figure 6-4 

acceder au contenu 

0 

0 

□ 

La permission Acceder au contenu 


• Create story content : nous le verrons plus loin, un contenu de type 
« story » est un article. Seuls les contributeurs disposent du droit de 
creer des articles. La presence de termes en anglais tient a ce que la 
traduction fra^aise de Drupal repose sur le travail de benevoles et est 
encore imparfaite. Referez-vous au chapitre « Gerer les langues » 
pour plus d ’informations. 


Droit d'acces 

utilisateur 

anonyme 

utilisateur 

identifie 

contributeur 


create story content 

□ 

□ 

0 

delete any page content 

□ 

□ 

□ 

delete any story content 

□ 

□ 

□ 

delete own page content 

□ 

□ 

0 


Figure 6-5 

Droit de creation et de suppression d'artide 
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Delete own story content : ce droit permet aux contributeurs de sup- 
primer leurs propres articles. 


Figure 6-6 

Droit d'edition d'un article 
et de visualisation des revisions 


Droit d'acces 

utilisateur 

anonyme 

utilisateur 
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contributeur 

edit own story content 
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0 

revenir sur les revisions 

□ 
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□ 

voir les revisions 
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• Edit own story content : comme le droit precedent, celui-ci permet aux 
contributeurs de modifier leurs propres articles. 

• Voir les revisions : pour permettre au contributeur de visualiser l’histo- 
rique des contenus. 

Permissions du module Contact 

Acceder au formulaire de contact global : nous voulons que tout le monde 
puisse nous contacter, nous cochons done aussi bien les utilisateurs ano- 
nymes que ceux identifies. 



Droit d'acces 

utilisateur 

anonyme 

utilisateur 

identifie 

contributeur 

Figure 6-7 

Les permissions a activer 
pour le module Contact 

module contact 




acceder au formulaire de contact 

global 

0 

0 

□ 


Permissions du module Path 

Le module Path permet de definir des alias entre le chemin natif d un con- 
tenu (ex. http://www.colchique-conseil.fr/node/12) et une version plus lisible de 
rURL (ex. http://www.colchique-conseil.fr/mon-contenu). Nous ne voulons done 
donner ce droit qu aux seuls contributeurs. Vous trouvez juste en-dessous 
la permission gerer les alias d'URL. II s'agit la d une action d’administration 
consistant a permettre a un role de modifier les alias crees, dans leur 
ensemble. Nous ne donnons done pas ce droit au contributeur. 


Figure 6-8 

Les permissions a activer pour le module Path 


utilisateur utilisateur 

D rort d'acces contribute ur 

anonyms identifie 

module path 

gerer les alias d'url □ □ □ 

creer des alias d'url D D |0! 
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Permissions du module Search 


Le module Search permet de rechercher dans les contenus en mode 
simple (une peu comme la recherche basique de Google) ou en mode 
avance (avec des criteres supplementaires). 

Generalement, nous donnons le droit de recherche simple a tout le 
monde, et la recherche avancee aux seuls utilisateurs authentifies. Cela 
s’explique principalement par le fait que la recherche avancee demande 
plus de ressources et qu on ne veut pas augmenter exagerement la charge 
machine en la rendant trop facilement accessible. 


Droit d'acces 

utilisateur 

anonyme 

utilisateur 

identifie 

contribute ur 

module search 

administrer la recherche 
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□ 

rechercher dans le contenu 

0 
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□ 
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Figure 6-9 

Les permissions a activer pour le module Search 


Permissions du module Upload 

Le module Upload va nous permettre d’attacher des fichiers binaires 
(PDF, images, etc.) a nos contenus. II convient done de donner le droit 
de transfert aux seuls contributeurs, mais en revanche, de permettre la 
visualisation des fichiers attaches a tous. Notez cependant qu en donnant 
le droit voir les fichiers transfers a l’utilisateur anonyme, ces fichiers 
seront aussi lus par tous les automates de recherche comme Google. A 
vous de decider si cela vous pose un probleme. 


Droit d'acces 

utilisateur 

anonyme 

utilisateur 

identifie 

contribute ur 

module upload 

tran sfe re r de s fic h ie rs 

□ 

□ 

|0J 

voir les fichiers tran sfe res 

0 

0 
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Bon a savoir 

Limitations specifiques a un role 

Lorsque vous donnez le droit transferer des 
fichiers a un role, une zone depliable dediee a ce 
role apparaitra dans le panneau de configuration 
du module Upload ( Configuration du site, puis 
Transfert de fichiers ). Dans cette zone, il sera 
possible de definir des limitations en taille et en 
resolution specifiques a ce role. A chaque fois que 
vous ajoutez un role, verifiez que ces valeurs sont 
bien celles auxquelles vous vous attendez. 


Figure 6-10 

Les permissions a activer pour le module Upload 


Permissions du module User 

Le module User va gerer tous les aspects de la vie d un utilisateur et plus 
particulierement son compte (ou profil). 

• Acceder aux profils des membres : en activant cette permission pour les 
utilisateurs anonymes et identifies, nous les autorisons, en cliquant 
sur le nom d un utilisateur, a acceder a leur profil et aux informations 
(non confidentielles evidemment) quil contient. 
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Figure 6-11 

Les permissions a activer pour le module User 


Droit d'acces 


utilisateur 

anonyme 


utilisateur 

identifie 


module user 

accede r aux pnofils des 

mem b res 

u 

0 

D 

administrer les droits d'acces 

□ 

□ 

□ 

administrer les utilisatsurs 

□ 

□ 

□ 

changer son nom d'utilisateur 

□ 

0 

□ 


Bon A SAVOIR Disposer cTun role 
Administrateur 

Comme cela a ete dit, il n'y a qu'un seul adminis- 
trateur sur un systeme Drupal, ce qui peut poser 
probleme lorsque nous voulons deleguer I'admi- 
nistration a un utilisateur tiers. II n'est en effet pas 
concevable de lui donner I'identifiant et le mot de 
passe administrateur. 

La solution consiste a creer un nouveau role Admi- 
nistrateur et de lui affecter toutes les permissions. 
En procedant de la sorte, il suffira par la suite 
d'affecter ce role a I'administrateur delegue pour 
qu'il puisse administrer le systeme. 

L'enorme avantage de cette methode est que ce 
role peut etre ajoute ou retire tres facilement. A 
noter qu'il est aussi possible de creer des versions 
allegees en ne cochant qu'une partie des droits. 


• Changer son nom d'utilisateur : ce droit est a votre discretion, il permet 
a un utilisateur de changer son nom d utilisateur dans son menu mon 
profit. 

Une fois toutes les cases correctement cochees, il suffit d’appuyer sur le 
bouton Enregistrer les droits d’acces pour que les roles deviennent effectifs. 


Parametrage des comptes utilisateur 

Qu’est-ce qu’un compte utilisateur ? 

Lorsqu’un visiteur arrive sur notre site, rien ne le distingue dun autre 
visiteur. Il est alors designe comme « anonyme ». Pour passer du statut 
d’anonyme a celui d’utilisateur identifie, il devra saisir un nom d utilisa- 
teur et un mot de passe. C’est dans ce but qu une boite d’identification 
est affichee sur chacune des pages du site. 


Connexion utilisateur 

Nom d'utilisateur : 


Mot de passe : 


Figure 6-12 

La boite d'authentification 


| Se connecter | 

Creer un nouveau compte 
Demander un nouveau motde 
passe 


Mais pour s’identifier, encore faut-il que lutilisateur dispose d un 
compte sur notre site. Nous allons done maintenant voir comment 
Drupal permet d’ajouter de tels comptes et comment leur associer les 
roles que nous venons de creer. 
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Choix du mode de creation d’un compte utilisateur 

Drupal propose de nombreuses options liees a la creation d’un compte 
utilisateur qu’il convient de maitriser pour adapter son fonctionnement a 
vos besoins. L’ensemble de ces options est concentre sur la page acces- 
sible par Gestion des utilisateurs puis Parametres des utilisateurs. 

Drupal offre trois manieres distinctes de creer un compte utilisateur, 
allant de la plus restrictive a la plus laxiste. Pour choisir l’un de ces trois 
modes, remontons au debut de la page Parametres des utilisateurs. 

Mode Administrateur seul 

Figure 6-13 

O Seuls les administrateurs du site peuvent creer de nouveau* compte s. Creation d Un C0lTipte par le S0U I OdlTliniStrateur 

II s’agit la du premier et du plus simple de ces trois modes qui demande a 
l’administrateur de prendre en charge l’entiere procedure de creation. En rea- 
lite, meme si vous choisissez l’une des deux autres options, l’administrateur 
gardera toujours le privilege de creation d’un compte. La seule difference est 
qu’avec ce mode il sera le seul et unique utilisateur habilite a le faire. 

Comme nous le verrons un peu plus loin, l’administrateur, apres avoir 
cree ce compte, pourra demander a ce qu’un courriel soit envoye au 
nouvel utilisateur pour le prevenir que son acces est pret. Vous pouvez 
modifier ce courriel a partir du modele se trouvant dans Bienvenue, nouvel 
utilisateur cree par I' administrateur . 

Mode Sans approbation 


O Les visiteurs peuvent creer leur propre compte sans approbation de I 'administrateur. 


Figure 6-14 

Creation d'un compte Sans approbation 


Dans ce second mode, n’importe quel visiteur aura la possibility de creer 
son propre compte. Les etapes du processus de creation sont les suivantes. 

1 L’utilisateur anonyme doit cliquer sur le lien Creer un nouveau compte 
present dans la boite Connexion utilisateur. Notez que si ce mode n’est 
pas selectionne, ce lien n’apparaitra pas. 

2 Un formulaire s’affiche oil l’utilisateur anonyme doit choisir son 
identifiant, son adresse courriel, puis valider. 

3 Si vous avez coche la case Exiger la verification de I'adresse e-mail quand 
un visiteur cree un compte, un message apparait indiquant qu’un cour- 
riel de confirmation lui a ete envoye. Le modele de ce courriel peut 
lui aussi etre modifie dans la sous-section Bienvenue, pas d'approbation 
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requise. Le cas echeant, si la case n est pas cochee, le processus passe 
directement a l’etape 6. 

4 Lorsque futilisateur refoit le courriel de confirmation, il doit cliquer 
sur le lien qui lui est donne ; il aboutit alors sur une page lui deman- 
dant de choisir cette fois son mot de passe. 

5 Lorsqu il a termine, lutilisateur clique sur le bouton Enregistrer. 

6 La creation du compte est terminee ; le compte est maintenant actif, 
et lutilisateur rec^oit un courriel de confirmation dont vous pouvez 
modifier le modele dans la sous-section E-mail d'activation du compte. 


Mode Avec approbation 


Figure 6-15 

Creation d'un compte Avec approbation 


® Les visiteurs peuventcneer leur pnopre compte, mais I 'approbation d'un administrates est 
requise. 


Il s’agit ici d un mode de creation hybride autorisant lutilisateur a creer 
son compte mais laissant a fadministrateur le soin de le rendre actif. 

Le processus de creation se passe done exactement comme pour le mode 
precedent, a une difference pres : lorsque futilisateur a saisi son identi- 
fiant et son adresse, il re<;oit cette fois le courriel dont le modele se 
trouve dans la sous-section Bienvenue, en attente d'approbation. 

A ce stade, le compte existe mais n est pas actif car bloque. Seul fadminis- 
trateur a le pouvoir de changer cette situation. Il est informe de lexistence 
du nouveau compte par un courriel contenant un lien vers le profil de futi- 
lisateur, et pourra ainsi le rendre actif. C’est aussi a cette etape que fadmi- 
nistrateur pourra affecter des roles specifiques au nouvel utilisateur. 

Lorsque fadministrateur a debloque le compte, futilisateur re^oit alors le 
courriel lui indiquant que son acces a ete active et a partir de ce point, les 
choses se deroulent de la meme maniere que pour le mode Sans approbation. 

Les trois modes etant decortiques, nous allons choisir pour notre 
exemple une creation Avec approbation en cochant Les visiteurs peuvent 
creer leur propre compte, mais I' approbation d'un administrateur est requise. 
Ceci nous permettra d’explorer tous les aspects de la creation de compte. 

Dans la foulee, nous allons aussi cocher Exiger la verification de I'adresse e - 
mail quand un visiteur cree un compte. Cette option indique a Drupal quil 
doit verifier les adresses saisies par les utilisateurs en leur envoyant un 
courrier de confirmation. 


Figure 6-16 

Activer la verification des adresses de courriel 


0 Exiger I a verification de I'adresse e-mail quand un visiteur cnee un compte 
Si cette case est cochSe, les nouveaus utilisateurB dsviont valide r le u r ad lesse e-mail avant de po 
motde passe gene re automatiquement. Si cette case estd£coch£e, les utileate u rs se ro nt co n nei 
cho eir le u r p rop re mot de passe. 
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Dans la zone de saisie suivante, il vous est possible d’aj outer des remar- 
ques qui seront inscrites dans l’en-tete du formulaire de creation de 
compte. II peut s’agir d’un avertissement legal, ou de toute autre infor- 
mation que vous avez besoin de communiquer avant que l’utilisateur ne vo 

cree son compte. Notez qu’il est possible d’inserer des balises HTML 
dans cette zone. Pour l’exemple, saisissez le code HTML suivant. 


Directives pour b creation d'un compte : 

Attention, ce compte <strong>ne sera active</stronjg> qu'apnes approbation de 
I 'administrate urdu site| 


Ce teate est affiche dans la partie superieure du formulaire de creation de compte. II sert a 
do nner des directives ou des informations a vos futurs utilisate u rs. 


Figure 6-17 

La directive de creation d'un compte permet de prevenir 
les utilisateurs du mode de creation de compte. 


Avant de poursuivre, vous aurez remarque que dans la liste des modeles 
dont nous disposons, il reste trois cas que nous n’avons pas encore 
examine : 

• Mail d'oubli de mot de passe : qui, vous l’aurez compris, est le message 
envoye a un utilisateur ayant clique dans la boite de connexion sur le 
lien Mot de passe oublie ; 

• E-mail de notification d'un blocage de compte : qui correspond au cour- 
riel envoye a l’utilisateur dont le compte a ete desactive (etat 
« bloque ») par l’administrateur ; 

• E-mail de notification de suppresson de compte : qui correspond au 
courriel envoye a lutilisateur dont le compte a ete detruit par Tadmi- 
nistrateur. 


Parametrage des courriels lies aux etapes de creation 
d’un compte 

Comme nous l’avons vu, de nombreux courriels peuvent etre envoyes 
lors du processus de creation d un compte. Il est evidemment possible de 
modifier chacun des textes contenus dans ces courriels par le biais de 
modeles disponibles plus bas sur la meme page. 

Pour chacun de ces modeles, vous pouvez changer l’objet du courriel et 
son corps. Mais plus important, il vous sera possible d ’inserer dans ces 
textes des mots-cles qui seront au moment de l’envoi remplaces par leur 
valeur associee, a l’instar des champs d’un traitement de texte. 
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Figure 6-18 

Definition d'un modele de courriel 


Personnalbez re-mail de bbnvenue envoys aux nouveaux me mb ies ap res le u r e meg istre me nt, loraque bur 

approbate n eat leqube. Les va rab bs d ispo n b bs so nt : ! username. Isite, Ipassword, !uri, ! u ri b lie F. Imailto, 

Idate, ! log in u ri, led rt u ri. !bgin_url. 

Objet : 

| Details du compte de lusername sur Isite (en attente de validation par Padminis] 


Corps : 

l uiarnamB , 

Menci de votre inscription sur Isite. Votre demande de compte est actuellementen 


Ces champs se distinguent par le point d’exclamation qui les precede, en 
voici la liste : 

• Isite sera remplace par le titre de votre site ; 

• ! uri sera remplace par l’adresse de votre site (ex. http://www.mon_site.fr) ; 

• !uri_brief sera remplace par l’adresse courte de votre site (ex. 
www.mon_site.fr) ; 

• ! 1 ogi n_uri sera remplace par un lien pointant sur une page de saisie 
du nom d utilisateur et du mot de passe ; 

• ! username sera remplace par le nom de lutilisateur cree ; 

• ! password sera remplace par son mot de passe ; 

• ! mai 1 to sera remplace par l’adresse courriel de lutilisateur ; 

• !login_url, a ne pas confondre avec !login_uri, sera remplace par 
un lien qui permettra a lutilisateur de se connecter au site sans avoir a 
saisir son mot de passe. Ce lien est a usage unique et represente, par 
exemple, un moyen bien pratique de le laisser choisir lui-meme son 
mot de passe lors d une premiere connexion ; 

• ! edi t_url sera remplace par un lien pointant sur la page de profil de 
Tutilisateur, lui permettant de changer les parametres de son compte 
apres s’etre authentifie ; 

• Idate sera remplace par la date de creation du compte. 

Nous savons maintenant comment fonctionnent les modeles, voyons a 
present ce qu il en est de la creation dun compte. 

Signatures et portraits 

Les deux dernieres sections de la page Parametres des utilisateurs permet- 
tent respectivement d’activer et de desactiver la gestion des signatures et 
des portraits. 


102 


www.frenchpdf.com 


Signatures 


Gestiondes signatures : 

■ ' Desactive 


Figure 6-19 

Activation des signatures 


Les signatures sont de courts messages qui seront ajoutes automatique- 
ment a la fin de chaque commentaire poste par lutilisateur. En activant 
cette option, ce dernier pourra changer sa signature dans sa page Mon 
compte. Notez que ces signatures sont dynamiques, c’est-a-dire que si 
futilisateur en change, elle sera aussi modifiee pour fensemble de ses 
commentaires deja postes. 


Portraits 


Support des portraits d'utilisateurs : 

O Des active 
® Active 


Figure 6-20 

Activation des portraits 


Les portraits (ou avatars) sont quant a eux de petites images liees a l’uti- 
lisateur qui sont affichees soit dans ses commentaires, soit dans les arti- 
cles et autres contenus dont il est hauteur. Ici aussi, le portrait, s’il est 
active, est gere dans la page Mon compte. 

Des lors que vous activez les portraits, une nouvelle partie de formulaire 
apparait. Elle vous permet de specifier le dossier dans lequel vont etre 
stockees les images. Generalement, il s’agit du dossier picture contenu 
dans le dossier files que nous avons defini au chapitre precedent, a la 
section « Le parametrage general de Drupal ». 


Dossier conte narrt les portraits : 


| pictures 


So us-repe rto ire d u repe rto ire Btte&'defautt-'files.' dans leq ue I les po rtraits se re nt stooges. 


Figure 6-21 

Dossier de stockage des portraits 


i 

vo 


Vous pouvez aussi specifier les Dimensions maximales du portrait , fixees a 
85 x 85 pixels par defaut. Toute image plus grande sera refusee. Pour 
notre site, nous allons choisir une taille moins importante de 
48 x 48 pixels. 


Dimensions maximales du portrait : 

1 4 S s| ] 


Dimensions max i males des portraits, en pixels. 


Figure 6-22 

Dimensions maximales des portraits 
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kilo-octets. Par defaut, toute image de plus de 30 Ko sera rejetee. 
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Figure 6-23 

Poids des portraits 


Taille de fichier maximale des fichiers de portrait : 



Taille de fichier max. imale dea po rtiaits, en Ko. 


Comme pour la creation de compte, il est possible d’aj outer des direc- 
tives concernant les portraits. Tout ce que vous saisirez ici sera automati- 
quement inclus dans le formulaire d’aj out de portrait dans la section Mon 
compte de l’utilisateur. II peut s’agir la aussi d’un avertissement pour pre- 
venir, par exemple, que le compte sera bloque si les images ajoutees con- 
treviennent a la charte de deontologie du site. 

Une fois les parametrages termines, appuyez sur le bouton Enregistrer la 
configuration. Drupal vous indique alors que les nouveaux parametrages 
sont pris en compte et que le dossier de stockage des portraits a ete cree. 


Figure 6-24 

Message de Drupal attestant 
de la sauvegarde de la confirmation 


Parametres des utilisateurs 


Les options de configuration ont ete en registries. 

Le repertoire sites/defaultfliles/pictures a ete cree. 


Gestion des utilisateurs 


Creation manuelle d’un utilisateur 

Quel que soit le mode de creation choisi, 1’administrateur dispose syste- 
matiquement du pouvoir de creer ou de modifier manuellement un 
compte, et bien sur de le supprimer. Nous allons mettre cet aspect en 
pratique en creant le compte de Marine qui aura pour role Contributeur. 

La premiere chose a faire est d’aller sur la liste des utilisateurs connus de 
Drupal. Dans le menu Gestion des utilisateurs , cliquez sur le lien 
Utilisateurs ; apparait alors une liste d’utilisateurs se reduisant pour 
l’heure au seul administrateur. 


Figure 6-25 

Pour I'instant, I'administrateur 
est seul sur son Drupal. 


5 semaines 3 

□ administrateur actif il y a2 min 6 sec modifier 

jours 
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En haut de la page se trouve un onglet Ajouter un utilisateur sur lequel 
nous allons cliquer pour arriver sur le formulaire de creation de compte. 


Informations du compte 


Nom d' utilisateur : 

^Marine | 

Les e^aces soml auto rises, mais pas les signes de ponctuation a [exception des points, tiaits d'unbns at chie 


Adresse electronique : 

| m ari ne@co Ic h iq ue-co n se i I .f r 


Une adia$e e-mail valide. Toua Isb messages de ce syafeme BBiont envayes a cette ad lease. Cette ad res 
que ai voub desirez obtsnir un nouveau motde passe ou recevo ir personnel^ me ni certaines nouvelleEou s 


Mot de passe : 

j Securite du motde passe : Haute 

Confirmer le motde passe : 


Concordance des mots de passe : Oui 


Entiez un mot de passe pour le nouveau compte dana les deux champs. 


Figure 6-26 

Creation du compte de Marine 
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La premiere chose a faire est de saisir le Nom d'utilisateur qui sera l’iden- 
tifiant utilise dans la boite de connexion. Dans notre cas, il s’agira done 
de « Marine ». 

Suit alors l’adresse courriel de I’utilisateur qui doit absolument etre 
unique, avec le mot de passe en double exemplaire. Rappelez-vous bien 
que vous devez pour vos tests saisir ici une adresse courriel valide que 
vous lisez regulierement. Dans le cas contraire, vous ne recevriez jamais 
les courriels envoyes par Drupal. 


Statut: 

O Bloque 
® Actif 


Figure 6-27 

Statut de I'utilisateur 


A la suite se trouve le statut du compte, qui peut etre Actif ou Bloque. Ici, 
nous choisissons logiquement Actif. 


Roles : 

0 utilisateur identifie 
® contributeur 


Figure 6-28 

Attribution du role Contributeur a I'utilisateur Marine 


Viennent alors les fameux roles que nous allons affecter a rutilisateur 
Marine. Comme vous le constatez, par defaut Marine est consideree 
comme utilisateur identifie. A cela, nous allons ajouter le role contributeur. 

Figure 6-29 

101 Notifier I'utilisateur de son nouveau compte Envoj £ |' ut j|j sateur de la notification de Cation de SOn COmpte 
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Bon a savoir 

Ou changer les portraits et signatures ? 

Vous constaterez que le choix du portrait utilisa- 
teur ou de la signature n'est pas disponible dans 
ce formulaire. Ceci s'explique par le fait que la 
creation d'un utilisateur ne comporte que les ele- 
ments qui lui sont essentiels. 

L'utilisateur pourra par la suite modifier tous ces 
details via le menu Mon compte. 


Figure 6-31 

Drupal n'arrive pas a envoyer de courriel. 


Figure 6-32 

L'utilisateur Marine est apparu dans la liste. 
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Vous pouvez ensuite cocher la case Notifier l'utilisateur de son nouveau 
compte qui aura pour effet, comme nous l’avons vu, d’envoyer un courriel 
a Marine pour la prevenir que son compte utilisateur a ete active. 

Lorsque nous avons fini, il suffit d’appuyer sur le bouton Creer un nou - 
veau compte pour obtenir un message de Drupal confirmant la bonne fin 
du processus de creation. 


Un motde passe ainsi que des instructions detail lees ontete envoyes au nouvel utilisateur Marine. 


Figure 6-30 Message de confirmation de la creation du compte 

Si vous obtenez en plus du message precedent lerreur suivante, reportez 
vous au chapitre « Mettre en place son environnement de developpement », 
a la section « Resolution des problemes techniques ». 


Unable to send e-mail. Please contact the site administrator if the problem persists. 


En cliquant sur le lien Liste dans les onglets en haut de page, vous etes 
alors renvoye sur la liste des utilisateurs parmi lesquels apparait cette fois 
Marine. 


□ 

Marine 

actif 

contributeur 

19 sec 

il y a 19 se 

□ 

administrateur 

actif 


2 heures 52 min 

il y a 1 sec 


Vous constatez a cette occasion que le role Contributeur de lutilisateur 
est clairement indique dans la liste, le role Utilisateur identifie etant 
quant a lui sous-entendu. 

Creation d’un compte par l’utilisateur lui-meme 

Puisque nous maitrisons la version manuelle de la creation de compte, 
voyons comment creer un compte de maniere automatique. Pour faire ce 
test, vous devez prealablement vous deconnecter en cliquant sur le lien 
Se deconnecter du menu Administrateur. 

Vous etes maintenant sur la page visible par les utilisateurs anonymes, 
avec sur la droite, une zone permettant de se connecter avec ses identi- 
fiants. Pour simuler la creation d un compte, nous allons done cliquer sur 
le lien Creer un nouveau compte. 
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Attention, ce compte ne sera active qu'apres approbation par I'administrateurde ce site. 


Nom d'utilisateur : 


Leb espaces 3onl aulor&?B, itibe pas lea signea de ponctuatbn a reception dea points, Lrails d'unbns et caracleres de aoulignemenl. 



Adresse electronique : 

| Philippe@colchique-conseil.fr] 


Une adiesse e-mail valbe. Toua lea messages de ce sysb&me se ro nt e nvoyes a cetbe adiease Cette adre^e ne 3eiH pas lendue publiqL 
passe o u lecevo ir pe rao n ne lie me n t ce rta inea no uve Ilea o u ave ilbse me n Is. 


Creer un nouveau compte 


Figure 6-33 

Formulaire de creation automatique 
d'un nouveau compte 
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Nous avons ici le formulaire decrit plus haut, et allons saisir le nom 
d’utilisateur - ici « Philippe » - avec son adresse courriel, avant 
d’appuyer sur le bouton Creer un nouveau compte. Remarquez le texte 
divertissement affiche en haut du formulaire reprenant ce que nous 
avons saisi dans la section Parametres des utilisateurs. 

Drupal renvoie alors un message indiquant que la demande a bien ete 
prise en compte et quelle est en attente de validation, ce qui est con- 
firme par les deux courriels que nous venons de recevoir - lun a Y admi- 
nistrates, le second a Philippe. 

Uadministrateur a pour tache d’activer ce nouveau compte qui pour 
l’instant a pour statut Bloque. II clique pour cela sur le lien indique dans 
le courriel qui l’amene au meme formulaire que pour la creation 
manuelle d un compte, mais prerempli avec les valeurs saisies par Phi- 
lippe. II lui suffit alors simplement de cocher la case Active pour rendre le 
compte operationnel. 

Dans la foulee, fadministrateur va aussi assigner le role Contributeur a 
Philippe et appuyer sur le bouton Enregistrer. 

Une fois le compte active, Philippe re^oit un nouveau courriel lui per- 
mettant de se connecter, et de finaliser ainsi le processus de creation. 

Comme vous le voyez, ce mode mixte de creation de compte presente de 
nombreux avantages. II donne a fadministrateur la possibility de filtrer 
les « faux » utilisateurs qui peuvent etre des spammeurs. Mais il permet 
surtout de laisser a lutilisateur le choix d un mot de passe quil sera seul a 
connaitre, et d’eviter ainsi de faire circuler ce dernier dans un courrier 
lisible par n importe qui. 

Administrer les comptes utilisateur 

Lorsque plusieurs centaines de comptes ont ete generes par les utilisa- 
teurs eux-memes, avec ou sans approbation, il devient impossible de 
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Figure 6-34 

La zone de filtrage de la liste des utilisateurs 


Figure 6-35 

La liste des utilisateurs 
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gerer les activations ou les blocages au cas par cas. Fort heureusement, la 
liste des utilisateurs que nous avons entrapertpie precedemment se revele 
etre un outil puissant de gestion des comptes qu il convient de savoir 
manipuler. Pour tester cette fonctionnalite, nous allons prealablement 
nous deconnecter pour creer un nouveau compte pour l’utilisateur 
Karine. Ceci fait, reconnectez-vous en tant quadministrateur. 

Pour retrouver la liste des utilisateurs, vous devez cliquer, dans la section Ges- 
tion des utilisateurs , sur Utilisateurs. La page qui saffiche alors se compose de 
trois parties : la zone de filtrage, les actions applicables et la liste elle-meme. 


Afficher uniquement les utilisateurs ou 


O role 

O permission 
O statut 



La zone de filtrage permet de reduire le nombre d’elements dans la liste 
en ajoutant des criteres de filtrage. La marche a suivre consiste a cocher 
un seul des trois types de criteres : role, permission ou statut. 

Le critere role nous permet de filtrer tous les utilisateurs ayant un role 
donne. Le critere permission nous permet de choisir Tune des permis- 
sions (droit d’acces) que nous avons precedemment etudiees et de n affi- 
cher que les utilisateurs ayant le droit d’acceder a cette fonctionnalite. 
Enfin, le critere statut nous permet de n afficher que les comptes utilisa- 
teur actifs ou bloques. 

Une fois le type de critere choisi, vous devez selectionner une valeur pour 
ce critere puis cliquer sur le bouton Filtre pour l’appliquer. Ne seront alors 
affiches dans la liste que les elements repondant au critere defini. Vous 
pouvez ensuite aj outer un autre critere et cliquer cette fois sur Af finer , ou 
alors revenir a la liste de depart en appuyant sur le bouton Reinitialiser. 

La liste contient quant a elle tous les utilisateurs connus du systeme 
Drupal. Nous y retrouvons Karine, que nous venons de creer et qui est 
encore a l’etat bloque. 


□ 

Norn d'ulilisateur 

Statut 

Roles 

Membre depuis^ 

Dernier acces 

□ 

Karine 

bloque 


3 min 9 sec 

jamais 

□ 

Philippe 

actif 

contributeur 

19 min 49 sec 

jamais 

□ 

Marine 

actif 

contributeur 

53 min 9 sec 

il y a52 min 59 sec 

□ 

administrateur 

actif 


2 heures 50 min 

il y a2 min 2 sec 
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Cette liste des utilisateurs est constitute de colonnes sur lesquelles il est 
possible d’effectuer un tri croissant ou decroissant, en cliquant le nombre 
de fois necessaire sur le libelle correspondant. Chaque ligne dispose 
d : une case a cocher faisant office de selection. La case a cocher sur la vo 

ligne d’en-tete du tableau permet de selectionner ou deselectionner 
l’ensemble des elements de la page. Enfin, un lien editer est present en 
fin de ligne donnant acces au formulaire de modification du compte. 

Linteret de la selection reside dans la derniere zone de la page, les 
Options de mise a jour. Vous y trouverez une liste deroulante d’actions a 
appliquer sur la selection. II est ainsi possible de bloquer ou d’activer un 
ensemble de comptes d un seul coup, de supprimer des comptes, mais 
aussi d’ajouter un role particulier a un ensemble de comptes. Ici, nous 
allons selectionner Karine et choisir foption de mise a jour Debloquer les 
utilisateurs selectionnes. Puis, nous allons renouveler foperation avec cette 
fois Ajouter un role aux utilisateurs select\onnes! contributeur . 


Options de mise a jour 

| contribute ur C|| Mise a jour | 


□ 


Nom d'utilisaLeur 


Statut Roles 


Membra deputed 


Dernier acces 


Operations 



D Philippe actif contributeur 20 min 54 sec jamais editer 

D Marine actif contributeur 54 min 14 sec il y a 54 min 4 sec editer 

□ administrateur actif 2 heures 52 min il y a 1 sec editer 


Figure 6-36 

Attribution a Karine du role 
Contributeur 


Pour appliquer une action a une selection, il suffit done de la choisir puis 
d’appuyer sur le bouton Mise a Jour. Une page de confirmation resumant 
la liste des comptes a modifier s’affiche alors et apres validation, les 
modifications sont effectuees. 


Changer rapidement d’utilisateur 

Dans la suite de ce livre, nous allons tres regulierement endosser le role 
de fadministrateur, du contributeur, ou d’autres roles, de maniere a 
tester Drupal sous tous les angles. A chaque fois, il faudra done se 
deconnecter, puis se reconnecter en saisissant l’identifiant et le mot de 
passe de l’utilisateur dont nous prenons la personnalite. Cette operation 
risque de devenir tres rapidement fastidieuse. 
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URL Module Masquerade 

► http://drupal.org/project/masquerade 


Figure 6-37 

Reglages du module Masquerade 


Figure 6-38 

Reglages du module Masquerade 


Figure 6-39 

Le bloc de changement rapide d'utilisateur 
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Fort heureusement, il existe un module extremement pratique permettant 
de basculer automatiquement d un utilisateur a un autre, Masquerade. 

Telechargez, installez et activez ce module, puis rendez-vous dans la 
section Administration > Configuration du site puis Masquerade. Vous 
pouvez ici parametrer le module. Le principe est d’autoriser l’adminis- 
trateur a endosser rapidement l’identite de l’utilisateur contributeur. 
Pour ce faire, configurez le module comme sur la copie d’ecran suivante. 


Default test user : 


Enter the username of an account you WEh to switch easily between vis a menu Hei 


o 

i. The name 


must be an exerting user 


Quick switch users : 


administrate ur 

Karine 

Marine 

Philippe 





Select the use mames To r acco u n Is to show as quick links in the Masquerade block. 


Cela permet a l’administrateur (et seulement lui) de pouvoir rapidement 
basculer sur Tidentite de Marine. Attention de ne pas selectionner de 
roles supplementaires dans la section Roles that are considered 
« administrator », sinon vous risquez d’ouvrir une grande faille de secu- 
rity sur votre site. 

Enregistrez la configuration, et rendez-vous dans Administration > Cons - 
truction du site puis Blocs. Nous verrons en detail a quoi correspond cette 
page plus loin dans ce livre ; pour l’heure, recherchez simplement la 
ligne Masquerade et dans la liste deroulante, selectionnez la valeur Barre 
de gauche puis enregistrez. 


+J+ Masquerade | El arte de gauche C 


Si tout s’est bien passe, vous devez voir apparaitre un nouveau menu 
Masquerade a gauche de la page. 


Masquerade 



Enter username lo masquerade 

r°°~ i 


Quick switches: 
ad m in istra te u r 
Ms rine 


www.frenchpdf.com 


Ce menu n est visible que pour le role Administrateur. Lorsque vous cli- 
quez sur le lien Marine , vous devenez automatiquement cet utilisateur. 

Pour preuve, vous voyez apparaitre un message d’erreur « Acces refuse » 
car effectivement, Marine n a pas le droit de modifier les blocs. Sur le & 

cote gauche, vous remarquez que le menu precedent a lui aussi change, 
vous indiquant (en anglais malheureusement) que l’utilisateur courant 
est bien Marine et vous donnant un lien Switch back qui vous permettra 
de redevenir administrateur. 

Ce module nous fera gagner enormement de temps dans la suite de 
notre decouverte. Ceci etant dit, comme pour le module Administration 
menu que nous avons installe dans le chapitre precedent, le reste de ce 
livre ne fera pas de reference directe a ce module. C’est done a vous de 
l’installer et de l’utiliser si vous le souhaitez. 


Regies d’acces 

Le dernier aspect de la gestion des utilisateurs consiste a definir un 
ensemble de regies d’acces au site dont le but est la lutte contre les com- 
portements indesirables. Nous pourrons non seulement bloquer ou auto- 
riser la creation de nouveaux comptes, mais aussi l’utilisation de comptes 
existants en fonction du nom de l’utilisateur, de son adresse electronique 
ou encore de son nom de domaine. 

Vous pouvez ainsi decider qu’aucun utilisateur ne puisse choisir « pirate » 
comme identifiant, que seuls les utilisateurs provenant dune adresse IP 
commen^ant par 10.0.0 ont le droit de creer un compte ou encore que 
les utilisateurs provenant du domaine pirates.com sont interdits. 

Pour parametrer ces regies d’acces, vous devez vous rendre dans le menu 
Administrateur > Gestion des utilisateurs puis Regies d'acces. Drupal affiche 
alors une page contenant une liste de regies - vide pour l’instant. 

Regies d'acces Eikt A i° uter une ^' e 

Definissez les regies pour les noms d 'Util is ate u ret les mots de 
comptes actue lie merit co nnectes ne seront pas deconnectes). 
rejet mais pas a une regie d'autorisation, aucun compte ne poL 
s 'identifier. Une regie sur le nom de domaine empeche tout ao 

Figure 6-40 

liny a actuellement aucune regie d'acces. La liste deS TeCjleS d aCCeS 311 Site 
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Pour aj outer une nouvelle regie, vous devez cliquer sur Tonglet Aj outer 
une regie. Un formulaire s’affiche alors pour permettre le parametrage de 
notre restriction. 

Cela commence par le choix de Taction de restriction a effectuer : Auto - 
riser ou Refuser. Pour notre premiere regie, nous commencerons par 
interdire le choix de Tidentifiant « pirate » et selectionnons done Refuser. 

Notre restriction portant sur le nom d’utilisateur, nous choisissons dans 
la section Type de regie Toption Nom d'utilisateur. II ne nous reste alors 
plus qu’a saisir pi rate dans le champ Masque. 

Notez que dans ce champ, il est possible d’etendre la restriction en utili- 
sant le caractere % qui se substituera a n importe quelle chaine de carac- 
teres. Ainsi, pour interdire non pas uniquement Tidentifiant « pirate » 
mais tous les identifiants contenant le mot « pirate », nous saisirons 
%pi rate%. De la meme maniere, si nous voulons interdire un mot a une 
lettre pres, nous utiliserons le caractere Ainsi, pi rate_ bloquera 
pi rate mais aussi pi ratel, pi rateA, etc. 

Lorsque notre regie est definie, il ne reste plus qua appuyer sur le 
bouton Ajouter une regie pour Tactiver. Drupal nous repositionne alors 
sur la liste contenant notre nouvelle regie. Il est alors possible de la 
modifier, de la supprimer ou d’en ajouter une nouvelle. 

Pour etre certain que nos regies fonctionnent comme nous le souhaitons, 
il est possible de les tester en cliquant sur Tonglet Verifier les regies. Appa- 
raissent alors trois zones de saisie correspondant aux trois types de 
regies. Si nous saisissons grand_pi rate dans le champ Nom d'utilisateur et 
que nous appuyons sur le bouton Verifier le nom d'utilisateur , le message 
suivant devrait alors apparaitre : 


Figure 6-41 

Message de confirmation Le nom d ' uti|isateijr s ran£ 0 5 ' rate n ' est p qs autonss. 

du bon fonctionnement de notre regie 

Nous constatons ainsi que notre regie est maintenant effective. Ce sys- 
teme peut etre tres utile si vous constatez des attaques massives prove- 
nant d une adresse IP donnee, car il vous sera alors aise de bloquer les 
utilisateurs indelicats. 


La page Mon compte 

Nous avons pour Tinstant beaucoup etudie les utilisateurs sous Tangle de 
Tadministrateur. Nous allons maintenant changer de point de vue pour 
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etudier ce que tous ces reglages impliquent pour l’utilisateur, ce qui se 
resume essentiellement a son espace purement personnel au sein de 
Drupal : la page Mon compte. 

vo 

Acceder a Mon compte 


Marine 

° Mon compte 
Cneer un contenu 
Se deconnecter 


Figure 6-42 

Menu d'acces a la page Mon compte 


La page Mon compte regroupe toutes les informations et les reglages pro- 
pres a lutilisateur identifie. Par defaut, la partie information que Y on 
appelle aussi le « profil » de lutilisateur est relativement pauvre mais de 
nombreux modules peuvent venir greffer ici de nouvelles sections selon 
vos besoins. 


Marine 


Modifier 


Historique 

Mombne depus 
25 min 55 sec 


Figure 6-43 

Le profil de Marine 


Modification du profil 

Ce profil est aussi la page que pourra voir lutilisateur anonyme qui cli- 
quera sur un nom d’auteur de contenu ou de commentaires. Longlet 
Modifier est en revanche absolument specifique a lutilisateur connecte et 
ne peut etre vu que par l’administrateur ou lutilisateur qui dispose des 
droits suffisants. 

Nous retrouvons dans cet onglet des informations maintenant connues 
comme le nom de l’utilisateur, son adresse courriel et son mot de passe. 
Tout peut etre change dynamiquement par Marine. 

Dans la section Portrait , nous retrouvons la possibility donnee a lutilisa- 
teur de telecharger une image qui lui est propre. Une fois ce portrait 
choisi et le bouton enregistrer clique, la section Portrait change pour per- 
mettre la suppression ou le changement de fimage. 
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Figure 6-44 

Le portrait de Marine 


□ Sup primer le portrait 
Cochez cette case po u r supp rime r votre portrait actuel. 



Transferer un portrait : 

Pancourir. .. 

VotiB portrait, raelou virtue I. Les d ime nsio ns masimales sont de 48x48 e t h taille maximale estde 30 Ko. 


La section Parametre de signature permet a Marine de definir le court 
texte qui sera insere a la fin de chacun de ses commentaires. Comme 
nous le disions plus haut, ce message est change dynamiquement si 
Marine le modifie dans ses reglages. 

La section Parametre du contact est presente parce que nous avons active 
le module Contact. Elle permet a Marine de choisir, en cochant la case 
Formulaire de contact personnel , si elle desire ou non pouvoir etre con- 
tactee par ce biais. Si la case est cochee, tout utilisateur allant sur son 
profil pourra aussi la contacter. 

Enfin, la section Langue et parametres regionaux permet a Marine de 
definir son propre fuseau horaire (si elle travaille par exemple a 
l’etranger). Lorsque nous aborderons la gestion des langues, c’est aussi a 
cet endroit que futilisateur pourra definir la langue qu’il desire voir uti- 
liser pour son interface. 

Etendre le profil de I’utilisateur 

Si vous activez le module Profil (fourni en standard avec Drupal), vous 
avez la possibility d’ajouter dynamiquement des champs au profil de 
futilisateur. Lajout de tels champs est alors accessible par le menu Ges - 
tion des utilisateurs , puis Profils. 


Figure 6-45 

Ajout de nouveaux champs 
au profil des utilisateurs 


Titre Mom Type Ope ml ions 

Aucun champ disponible. 

Ajouter un nouveau champ 

O zone de texte simple 
zone de texte multiligne 
O caseacocher 
O liste de selection 
° liste libie 
URL 
date 
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Nous pouvons, pour l’exemple, cliquer sur l’ajout dun champ de type 
URL , qui nous donne acces a un formulaire de parametrage du champ. 

Saisissez dans Categorie : Coordonnees, dans Titre du champ : Page 
personnel le, dans Nom du champ (qui par une erreur de traduction est vo 

denomme Nom du formulaire) : profil_homepage, et entrez une even- 
tuelle petite Explication. 


Parametres du champ 


Categorie : 1 
Coordonnees 


□ 


La categorie a laquelle le nouveau champ appartie nd la. Les catego lies pe rmette nt de regiouper les champs 
de manieie logique. Esemple de categorie : " I nfo rmatio ns pe rso n ne lies" . 


Titre : * 

[Page personnels 

Le title du nouveau champ. Ilseia montie a T utilisate u r. Example de title : "Co u le u r favo rite" . 


Nom du formulaire : * 


[ p rof i le_ho me p age 


Le nom du champ. Le nom du formulaiie n'estpas montie a T utilisate u r. mais utilise en interne dans le code 
HTML et les UR La. Sauf si vous savez ce que vous faites. il est forte me nt lecommande de piefixer le nom du 
fdrmubiie avec profi"L_, de manieie a eviterdes conflits de nommage avec d'auties champs. Les spaces 
ou toutautie caiacteie, a Teaception du tiiet (-)etdu caiacteie de soulignage (_), sont inteidits. Eaemple de 
no m : "p rof il_co u le u r_favo rite" o u plus simp le me nt "p rof il_co u le u r" . 


Explication : 

La page personnels de I'utilisateur 


Figure 6-46 

Definition cTun champ Page personnelle 


Ensuite, vous pouvez determiner la visibility du champ, nous choisirons 
Champ public, contenu affiche sur la page de profit, mais non utilise sur la 
page de la liste des membres qui permet de rendre visible le champ a tous, 
mais de ne pas pour autant Tafficher dans la liste. Lorsque c’est termine, 
cliquez sur Enregistrer le champ. Vous etes alors renvoye sur la page Profit 
ou notre nouveau champ est apparu. 


Titre 

Nom 

Type 

Operations 

Coordonnees 




Page personnelle 

p rof i le_ho me p age 

url 

modifier 


Figure 6-47 

Le nouveau champ Page personnelle 


Si vous vous reconnectez en tant que Marine pour vous rendre sur 
l’onglet Modifier de M on compte, vous constaterez l’apparition d’un 
nouvel onglet portant le nom de la categorie que nous avons donne au 
champ, Tonglet Coordonnees. 


Marine Voir Contact 

Compte utilisateur 


Figure 6-48 

Apparition de Tonglet Coordonnees 
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En cliquant sur cet onglet, Marine peut saisir les informations sur sa 
page personnelle. 


Coordonnees 



Saisie des donnees pour 
le nouveau champ du profil 


Une fois Fonglet Coordonnees enregistre, la valeur du champ est automa- 


tiquement ajoutee a la page du profil de Marine. 


Marine 


Modifier Contact 



Coordonnees 

Rage personnelle 
http ://b log . m ari ne .o rg 

Historique 

Membredepuis 
1 heune 4 min 


Figure 6-50 

Le profil etendu de Marine 


Masquerade as Marine 


Modules magiques Profil et contenu 

Le profil d'un utilisateur n'est pas un contenu au sens general du terme. II jouit de ce fait d'un 
traitement particulier au sein de Drupal. Dans certains cas, il peut cependant etre utile que le 
profil soit un type de contenu a part entiere. C'est le role du module Content profi 1 : 

► http://drupal.org/project/content_profil 

L'avantage de cette approche est qu'un profil de type contenu peut etre recherche par le 
meme moteur de recherche que les articles, il peut aussi etre transforme en PDF, rendu impri- 
mable, envoye par courriel, etc. 
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En resume 

• Un role est une liste nommee de permissions. 

• Chaque module definit son propre jeu de permissions. 

• Drupal permet la creation d’autant de roles que necessaire. 

• A un utilisateur donne peuvent etre assignes autant de roles que 
necessaire. 

• Un utilisateur qui a saisi un identifiant et un mot de passe dispose 
automatiquement du role Utilisateur identifie. 

• Le visiteur ne possedant pas d'identifiant et de mot de passe associe a 
pour unique role Utilisateur anonyme. 
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chapitre 



Nom Type Description 

Un article, similaire dans la forme a Line page, est ideal pour 
creeret afficherdu contenu qui informe et pousse les visiteurs a 
reagir. Revues de presse, actual ite, billet de blog peuventetre 

Article story 

cnees avec un article. Pardefaut, un article est auto matique merit 
pub lie sur la page d'accueil de votre site et permet aux visiteurs 
d 'ajo ute r de s co m me ntai re s . 

Une page, similaire a un artrdedans s a forme, est une methode 
simple pour afficherdes informations qui changent rare me nt. 
comme la page "A propos"d'Lin site. Pardefaut. un contenu de 

Page page 

type page ne permet pas aux visiteurs de laisserdes 
commentaires. etcelle-ci ne sera pas publiee sur la page 
d'accueil. 


Operations 


modifier supprimer 


modifier supprimer 
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Creer du contenu 


Nous entrons ici dans le coeur du metier de Drupal : la gestion 
des contenus. Lors de ce premier contact, nous manipulerons 
le plus simple des types de contenu, qui est Tarticle, avant 
de voir comment creer et mettre en ligne des articles. Puisque 
mise en ligne implique de facto interaction avec vos visiteurs, 
nous etudierons pour fmir la maniere dont vous gererez leurs 
commentaires, techniquement mais aussi humainement. 


SOMMAIRE 

► Parameter et creer des types 
de contenu 

► Administrer les contenus 
et les commentaires 

► Comprendre les formats 
d'entree 
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Les types de contenu 

Pour un Drupal fraichement installe, les types de contenu disponibles sont 
au nombre de deux : Article et Page. Schematiquement, Article est des- 
tine a la creation d’articles, et Page a la creation d’elements statiques du 
site tels que les informations legales, la presentation de la societe ou l’aide. 

Pour chaque type de contenu, Drupal offre la possibility de definir un com- 
portement par defaut, en determinant la maniere de gerer les commen- 
taires, le mode de publication, ou encore la prise en charge des revisions. 

Ainsi, le type Article, qui est le type de contenu vivant par excellence, est 
parametre par defaut comme pouvant recevoir des commentaires ou 
encore etre publie en page d’accueil. A l’inverse, un contenu de type 
Page ne permet pas par defaut de recevoir de commentaires et n a pas 
vocation a etre visible sur la une de votre site. 

II faut cependant bien avoir conscience qu’il s’agit d un comportement 
de base, chaque module pouvant potentiellement ajouter de nouveaux 
parametrages aux differents types de contenu. 

Modification du type de contenu Article 

Pour modifier le comportement d un type de contenu, nous devons tout 
d’abord redevenir Administrates, puis dans le menu administrateur , 
nous diriger vers la section Gestion du contenu, puis Types de contenu. 

Nom Type Description Operations 

Un article, similaine dans la forme a une page, est ideal pour 

creeret afficherdu contenu qui informe et pousse les visiteurs a 

neagir. Revues de presse, actualite, billet de blog peuventetre 
Article story modifier supprimer 

cnees avec un article. Par defaut, un article est automatiquement 

publie sur la page d'accueil de votre site et permet aux visiteurs 

d'ajouterdes commentaires. 

Une page, similaine a un artrotedans sa forme, est une methode 

simple pour afficherdes informations qui changent rarement, 

comme la page "A pnopos" d'un site. Par defaut. un contenu de 
Page page modifier supprimer 

type page ne permet pas aux visiteurs de laisserdes 

commentaires, etcelle-ci ne sera pas publiee sur la page 
d'accueil. 

Sur cette nouvelle page, nous voyons apparaitre les types de contenu 
Article et Page evoques plus haut et nous verrons plus loin qu il nous 
sera possible d’en rajouter. Pour l’heure, concentrons-nous sur la ligne 
correspondant au type de contenu Article et cliquons sur le lien modifier. 
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Figure 7-1 

Les types de contenu standards de Drupal 


Identification du contenu 


En premiere partie de ce formulaire, nous trouvons les informations 
decrivant textuellement le type de contenu. 


Identification 

Nom : * 

[Article | 

Le nom affiche de ce type de contenu. Ce texte sera affiche dana la liste sur la page creer un contenu. Ce nom do it ce m me nee r par u ne lettie majuacule et 
ne doit conte nirque dea lettrea, chiffies, etespaces. Ce nom doitetie unique. 

Type : * 

[story | 

Le nom interne de ca type de contenu. Ce teste aeia utilbe pourcontmire TURLde la page creer un contenu pource type de contenu. Ce nom ne doit 
conte nirque dea lettrea minuaculea, deachiffiea, et dea caracterea de aoulignement. Lea caracte res de ao u lig ne me nt ae ro nt co nve rts e n train d' union lors 
de k contmctbn dea URL de la page Creer un contenu. Ce nom doit etie unique. 

Description : 

Un <Bm>article<^m>, similaine dans la forme a une <e m > p ag e </e m> , est ideal pour creer et afficherdu contenu qui informe et 
pousse les vi site urs a reagir. Revues de pnesse, actual ite : billet de blog peuventetre cnees avec un <em>article</em>. Par 
defaut, un oem>article</em> est automatiquement publie sur la page d'accueil de votre site et permet aux vi site urs d'ajouter 
des commentaines. 


Une breve deacrptbn de ce type de contenu. Ce teste sera affiche dana la liste qui ae tiouve sur la page creer un contenu. 


Figure 7-2 

Proprietes basiques 
d'un type de contenu Article 


Le Nom du type de contenu, ici Article, correspond a ce que le contri- 
butes verra lorsqu il cliquera sur Creer un contenu. 

Le Type est quant a lui l’identifiant interne utilise par Drupal pour 
reperer les contenus de type Article. II ny a aucune raison pour nous de 
modifier cet identifiant. 

La Description correspond quant a elle au petit texte affiche en dessous 
du contenu dans la page Creer un contenu. II nest pas utile de modifier 
cette partie - sauf si vous desirez la rendre plus explicite pour vos contri- 
buteurs. 

Les champs du formulaire de contribution 

La seconde partie du formulaire - Parametres du formulaire de contribu - 
tion - nous permet de modifier les intitules des champs litre et Corps. La 
aussi, la seule finalite dun tel changement serait de rendre tout ceci plus 
comprehensible pour un contributes. 

Le champ suivant, Nombre minimal de mots , permet de determiner a 
partir de combien de mots Drupal peut autoriser le contributes a 
publier son nouveau contenu. Par defaut, la valeur 0 indique qu il ny a 
aucune limite appliquee. 
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Figure 7-3 

Proprietes de publication d'un contenu 


Bon A savoir La permission 
Administrer les nceuds 

L'administrateur qui cree ou modifie un contenu 
aura acces a un formulaire beaucoup plus etendu 
que celui du contributeur, permettant de definir au 
cas par cas la valeur des elements que nous choi- 
sissons ici. II en sera de meme pour tout utilisateur 
dont le role dispose de la permission Administrer 
les noeuds. 


Figure 7-4 

Activation des fichiers attaches 


Comme pour la creation d un compte ou pour les avatars, vous pouvez 
ajouter des directives a afficher en tete du formulaire de creation d un nou- 
veau contenu, par exemple pour rappeler au contributeur ses obligations. 

Procedure de publication 

Options par defaut : 

□ Publie 

□ Promu en page d'accueil 

□ Epingle en haut des listes 
® Creer une revision 

Dans la section Procedure de publication , nous parametrerons la maniere 
dont le contenu est traite au moment de l’enregistrement. 

Nous retrouvons ici en toute logique le comportement que nous avons 
constate pour notre premier contenu. II sera bien Publie , c’est-a-dire 
rendu visible a tous, ainsi que Promu en page d'accueil. Epingle en haut des 
listes vous permet de conserver le contenu en haut de la liste, et ce meme 
si de nouveaux conte nus plus recents sont ajoutes. 

Enfin, le dernier choix permet de Creer une revision a chaque sauvegarde 
d un meme contenu. Les revisions sont des photographies a un moment t 
donne du contenu, permettant a Y administrateur de revenir en arriere pour 
retrouver l’etat du contenu avant modification. Nous etudierons cette 
fonctionnalite en detail un peu plus loin. 

Pour notre exemple, decochons Publie et Promu en page d'accueil , et selec- 
tionnons Creer une revision. Par consequent, une revision sera alors creee 
a chaque modification du contenu, et seul fadministrateur pourra 
publier et rendre visible les articles. 


Fichiers attaches : 

O Des active 
* Active 


Le dernier choix figurant dans cette section correspond a la gestion des 
fichiers attaches aux contenus. Comme pour un courriel, Drupal permet 
en effet au contributeur d’ajouter un ou plusieurs fichiers a un contenu. Ce 
reglage a ete ajoute par le module Upload. Dans le cas d un article, c’est 
une bonne idee d’activer fattachement de fichiers pour permettre au con- 
tributeur d’enrichir son contenu de divers documents de reference. Pour 
lexemple, nous activerons done cette option. 
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Parametres des commentaires 


Paranien e par defaut des commentaires : 

O Desactive 

O Lecture uniquement Figure 7-5 

® Lecture/Ecriture Definition du mode de gestion des commentaires 


Derniere section du parametrage dun type de contenu, mais non la 
moindre : la Gestion des commentaires. Le premier parametre qu’il est 
possible de definir ici est l’ouverture ou non des commentaires. Drupal 
nous propose ici trois possibility : 

• Desactive : indique que les commentaires ne seront tout simplement 
pas autorises pour ce type de contenu ; 

• Lecture/Ecriture : permet aux visiteurs de lire et ecrire des commen- 
taires pour ce type de contenu ; 

• Lecture uniquement : n autorise que la lecture des commentaires exis- 
tants, mais pas la saisie de nouveaux. 


Bon asavoir A quoi servent les 
commentaires en Lecture uniquement ? 

Autant le choix de I'une des deux autres options 
est comprehensible, autant I'option Lecture uni- 
quement a quelque chose de deroutant. 

En effet, quel interet y a-t-il a pouvoir lire des com- 
mentaires si personne ne peut en ecrire ? La 
reponse est... aucun. Ce choix est sans interet dans 
le parametrage d'un type de contenu et n'est 
jamais utilise a cet endroit. 

En revanche, il peut devenir particulierement utile 
lorsque vous decidez de fermer les commentaires 
sur un billet qui est soit trop ancien, soit trop 
« agite ». Line operation qui sera realisee par 
I'Administrateur. 


Mode de discussion 


Mode d'affichage par defaut : 

O A plat - replie 
O A plat - deplie 

O Par discussion - replie Figure 7-6 

® par discussion - deplie Definition du mode d'affichage des commentaires 


Le visiteur dispose de deux liens pour ajouter un commentaire. Soit il com- 
mente Tarticle en lui-meme, auquel cas il utilisera le lien Ajouter un com - 
mentaire qui se trouve juste en dessous de Tarticle lui-meme ; soit il veut 
repondre a un autre commentaire, auquel cas il cliquera sur le lien repond re 
en dessous de ce commentaire. Loption M ode d'affichage par defaut permet 
de gerer Taffichage des commentaires resultant de ces deux choix. 

Lorsque le mode Par discussion est selectionne, l’affichage des commen- 
taires correspondra a celui habituellement trouve dans un forum. Les 
commentaires crees par le lien Ajouter un commentaire seront affiches au 
meme niveau que l’article et ceux crees par le lien Repondre se position- 
neront sous le commentaire initial, decale d un cran vers la droite. Les 
reponses successives formeront ainsi une arborescence de commentaires. 

Si vous choisissez le mode A plat , les commentaires seront alors affiches 
sous la forme dune liste simple, quel que soit le lien de creation utilise. 
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Dans les deux cas, si vous choisissez l’option replie , seul le titre du com- 
mentaire sera affiche et il faudra cliquer dessus pour acceder a son con- 
tenu. En mode deplie , les contenus seront visibles d’emblee. 

Dans le cadre de notre exemple, le choix ici sera Par discussion - deplie. 

Ordre des commentaires 


Figure 7-7 

Ordre d'affichage des commentaires 


Ordre d'nttichnge par default : 

o Par date - du plus recent au plus ancien 
Par date - du plus ancien au plus recent 


Lorsquun visiteur reagit a un article en postant un commentaire, le 
court texte qui en resulte est alors affiche sous farticle lui-meme, soit Par 
date - du plus ancien au plus recent , soit Par Date - du plus recent au plus 
ancien. C est cet ordre que 1 option Ordre d'affichage par defaut permet de 
definir. Selectionnez Par Date - plus recent au plus ancien qui est le mode 
le plus usuellement utilise. 

Pagination des commentaires 


Figure 7-8 

Limitation du nombre 
de commentaires par page 


Commentaires par page par defairt : 


ll° A I 


De tres nombreux commentaires pouvant etre ajoutes pour un meme 
article, il peut devenir necessaire de les afficher sur plusieurs pages. Loption 
Commentaires par page par defaut permet de definir a partir de combien de 
commentaires Drupal passera a une nouvelle page (50 par defaut). 

Gestion des commentaires 


Figure 7-9 

Position du panneau 
de gestion des commentaires 


Gestion des commentaires : 

' - ' Afficher au-dessLis des commentaires 
O Afficher au -des sous des commentaires 
' - ' Afficher au -dessus et au -des so us des commentaires 
Ne pas afficher 


La gestion des commentaires est un petit tableau de bord permettant aux 
utilisateurs de regler eux-memes le mode d'affichage, fordre et la pagina- 
tion des commentaires. Il leur est aussi possible de memoriser ces choix. 
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[ Par discussion - replie C~| | Par date - du plus ancien au plus recent C j | 50 comment aires par page C | | Enregistrer les parametres J 
Selectionnez la methode d'affichage des commentaires que vous preferez, puis cliquez sur "Sauvegarder les parametres" pour activer vos changements. 

Figure 7-10 Panneau personnel de gestion des commentaires 

Vous avez ici la possibility cTactiver l’affichage de ce tableau de bord, et 
de determiner sa position dans la page. 

Commentaires des visiteurs anonymes 


Commentaires anonymes : 

O Les utilisateurs anonymes ne peuvent pas laisser leurs coordonnees 

O Les utilisateurs anonymes peuvent laisser leurs coordonnees Figure 7-11 

® Les utilisateurs anonymes do ivent laisser leurs coordonnees GeStion deS COmmentaireS pOUt l6S VisitGULS anonymes 


Lorsqu’un visiteur anonyme (c’est-a-dire non identifie sur le site) poste 
un commentaire, il est possible, avec Toption Commentaires anonymes , de 
definir s’il doit fournir une adresse courriel valide, de lui interdire de la 
laisser ou simplement de lui laisser le choix de le faire ou non. Generale- 
ment, il est d’usage d’obliger le visiteur anonyme a laisser une adresse 
(troisieme choix). Libre a vous d’activer cette option qui alourdit visuel- 
lement un peu la page. 

Champ sujet d’un commentaire 


Champ sujet du commentaire : 

® Des active 
O Active 


Figure 7-12 

Desactivation du champ sujet du commentaire 


Le commentaire peut etre precede par un sujet. Vous pouvez choisir par 
loption Champ sujet du commentaire de rendre ce dernier optionnel. 
Selectionnez done ici le mode Desactive car nous nen avons pas l’us age. 

Gestion de I’aper^u 


Aper^u: 

O Facultatif 
® Obligatoire 


Figure 7-13 

Activation de I'apergu sur un nouveau commentaire 


La personne qui commente peut obtenir un aper^u de son commentaire 
avant quil soit mis en ligne en appuyant sur le bouton Apergu. Dans la 
mesure ou les visiteurs anonymes ne peuvent pas modifier leurs com- 


Bonasavoi Apercu et utilisateurs identifies 

Malheureusement, il n'est pas possible de condi- 
tionner I'apergu au fait d'etre anonyme. Une fois 
que ce mode est choisi pour un type de contenu 
donne, il est actif pour tout le monde, y compris 
pour les utilisateurs identifies qui pourtant peu- 
vent modifier leurs commentaires. 
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Figure 7-14 

Position du formulaire 
de soumission des commentaires 


Figure 7-15 

Acces a la creation d'un nouveau contenu 


mentaires une fois ceux-ci valides - contrairement aux authentifies 
c’est une bonne idee de rendre cet aper^u Obligatoire. 

Emplacement du formulaire de commentaires 


E m place meiitdu formula ire de soumission de comments ire : 

® Afficher sur une autre page 

‘ - ' Affic he r e n -de s so u s de I a co ntri b utio n o li de s co m me ntai re s 

L’option Emplacement du formulaire de soumission de commentaire precise 
femplacement de la zone de saisie du commentaire : celle-ci peut etre 
situee sur une autre page ou a la fin de farticle. Le choix entre ces deux 
modes est avant tout une question de gout, pour 1’heure selectionnez 
Afficher sur une autre page. 

Notre type de contenu Article est maintenant pret a l’emploi, et nous 
pouvons creer notre premier article. 


Creation d'un contenu de type Article 

Sortons a present de notre role Administrateur pour devenir un Contri- 
butes. Pour cela, nous commen^ons par nous deconnecter et nous 
reconnecter pour devenir Marine, l’utilisateur possedant le role Contri- 
butes que nous avons cree au chapitre precedent. 

Le role Contributeur 

Une fois connecte en tant que Contributeur, la premiere chose que nous 
constatons est que le menu anciennement Administrateur a ete remplace par 
un menu equivalent mais beaucoup moins riche, appele cette fois Marine. La 
logique de ce menu reste identique et regroupe toutes les actions que ce role 
a le droit d’effectuer sur le systeme. II reflete done tres exactement les per- 
missions que nous avons parametrees dans le chapitre precedent. 

Marine 


Mon com pis 
Creer un contenu 
Se decon nectar 


Nous trouvons dans ce menu l’entree Mon compte permettant a lutilisa- 
teur de changer les parametres de son profil, et le lien Se deconnecter 


126 


www.frenchpdf.com 


pour retrouver un etat « anonyme » et eventuellement se reconnecter en 
tant qu Administrates. 

Ceci etant pose, entre ces deux elements de menu, nous avons Creer un 
contenu qui est, comme vous pouvez l’imaginer, le point d’entree obliga- 
toire pour creer un contenu de n importe quel type. En cliquant sur ce 
lien, vous voyez apparaitre la liste des types de contenu que Marine a le 
droit de creer, liste pour Tins tant reduite au seul type Article. 

Creer un contenu Figure 7— 16 

Article Creation d'un contenu de type Article 


Insistons sur le fait quun utilisateur identifie qui n aurait pas le role 
Contributeur ne verrait jamais le menu Creer un contenu. Ce dernier cor- 
respond en effet tres exactement au droit Creer un article que nous avons 
specifiquement donne au role Contributeur, et done a l’utilisateur 
Marine puisque ce role lui a ete affecte. 

Formulaire de creation d’un article 

Pour passer a la creation en elle-meme, cliquez simplement sur le lien 
Article. La page suivante est un formulaire qui nous permettra de saisir 
notre contenu de type Article. 


Creer ■Article 1 

Titre : 


Cneer un resume a partirdu curseur 

Corps : 


Les adresses do pages web et de messagerie electron ique sont transfbrmees en liens automatiquement. 

Tags HTML autorises : <a> <em> ^strong > ^cit e> <code> <ul><ol> <\\> <dlxdt> <dd> 

Les lignes et les paiag raphes vont a la ligne automatiquement. 

Plus d 'informations sur les options de formatage 

Figure 7-17 

Formulaire de saisie d'un contenu 

Enregistrer | | Apergu | de type Article 


Comme vous le voyez, le formulaire de saisie de contenu est tres simple, 
compose seulement dun titre et d un corps. II s’agit la de la structure 
basique d’a peu pres tous les types de contenu. 
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Nous allons commencer par saisir le litre de notre article, par exemple 
« Mon premier article ». Puis dans le champ Corps , nous allons saisir un 
court texte pour l’exemple : 

Titre : * 

|Mon premier article 


Crier un resume a partirdu curseur 

Corps : 


Figure 7-18 

Ceci est I'introduction de mon article 

Et ceci est son developpement... 

Titre et corps de I'article 



Notez au passage la partie grise en dessous de la zone d’edition du corps 
qui vous permet d’en agrandir la surface. C’est une constante ergono- 
mique que nous retrouverons sur 1’ ensemble des zones de texte des for- 
mulates Drupal. 


Bon A SAVOIF Notation HTML pour une 
separation manuelle de I'introduction 

Le meme effet peut etre obtenu en inserant la 
balise speciale <! --break--> entre I'introduc- 
tion et le reste de I'article. 


Figure 7-19 

Separation de I'introduction et du developpe- 
ment de I'article 


Le resume d’un article 

Ce que Drupal appelle le « resume » s’apparente davantage a l’introduc- 
tion dun article, et a une certaine importance. En effet, lorsque viendra 
le moment d’afficher une liste de contenus - par exemple la liste des 
billets recents - en premiere page de notre site, c’est cette introduction 
qui sera affichee et non I’article complet. Vous prendrez ainsi progressi- 
vement l’habitude de raisonner sur deux versions d’un meme article : la 
version dite « abregee » qui ne contiendra que le titre et I’introduction, et 
la version « complete ». 

Pour creer ce resume, placez simplement le curseur entre les deux lignes 
de notre corps et cliquez sur le bouton Creer un resume a partir du curseur 
(Split summary at cursor ). La zone de saisie va alors se separer en deux 
parties avec en haut le resume et en bas le reste de I’article. 


0 Afficher le resume en mode pleine page j Fusionner le resume et le corps du message | 

Corps : 

Ceci est I'introduction de mon article 


Et ceci est son developpement... 


II est possible a tout moment de revenir en arriere en cliquant sur le 
bouton Fusionner le resume et le corps du message (Join summary). La case 
a cocher Afficher le resume en mode pleine page permet quant a elle de 
determiner si ce resume n’est visible que lors de l’affichage du contenu 
dans une liste (decochee) ou s’il est aussi present lorsque le contenu est 
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affiche au complet (cochee). Dites-vous que lorsque cette case est 
cochee, la premiere zone est effectivement une introduction a notre 
texte, et lorsqu’elle est decochee il ne s’agit que d’un resume. 

Decrire votre creation 

Nous verrons dans le prochain chapitre a quoi sert concretement la sec- 
tion Informations sur les revisions. Pour l’heure, dites-vous qu il est de bon 
ton, lorsqu on travaille a plusieurs, de decrire chacune de ses creations de 
contenu, mais aussi les modifications qui suivront. Nous saisirons ici un 
petit message qui indiquera aux autres nos motivations pour creer cet 
article. Cette description, nous le verrons un peu plus loin, sera visible 
dans fonglet Revisions du contenu. 


Ergonomie 

Redimensionnement des zones de texte 

Notez que la decoupe automatique du resume, 
ainsi que la possibility de redimensionner les 
zones, ne sont accessibles que si vous avez active 
JavaScript dans votre navigateur. 


Informations sur les revisions 


Message de journal : 

On atous commence un jour i| 


Une explication des ajouts et modifications que vous apportez pour aide rd'auties auteurs a 
comp lend re vos motivations. 


Figure 7-20 

Une courte description de la contribution 


Attacher un fichier 

Drupal, a travers le module Upload que nous avons active dans le para- 
metrage du type de contenu Article au cours du chapitre 6, nous permet 
d’attacher des fichiers a nos articles. Nous disposons done a la fin du for- 
mulaire d’une section dediee a cet usage. 


V Fichiers attaches 

Les changements apportes aux fichiers attaches neseront definitifs qu'a partir du moment oil vous 
enregistrerez cette contribution. Le premier fichier de la listesera inclus dans les fils RSS. 

Attacher un nouveau fichier : 

| /ho me.'m ari ne/B u re au/M an ue I uti I i s ate u r. pdf| P arco urir. . 

La faille maximale des te lec harge me n ts est T Mo. Seuls les fichiers avec les extensions suivantes peu vent 
etre tra nsfeies : jpg j peg gif png txtpdfppt odt ods odp doc xts pps. 

Figure 7-21 

I Attacher Attachement d'un ficher a I'artide 

Pour ajouter un fichier, appuyez sur le bouton Parcourir... Lorsque vous 
validez votre selection, le chemin complet de votre document doit appa- 
raitre dans le champ Attacher un nouveau fichier. Pour l’inserer dans le 
contenu, appuyez sur le bouton Attacher. Une liste apparait alors conte- 
nant les informations sur le fichier que vous venez d’attacher. 
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Figure 7-22 

La liste des fichiers attaches 


Supprimer Liste 


Description 


Taille 


£ 


□ 


0 


| Manuel utilisateur.pdf 

http:,' 'www >cdc liqje-conseil . Ir.'ei tee-www .cdc Nque-ccnseil . It-' file's MnnueJ utilise leu pdl 


274.03 

Ko 


Ergonomie L'ordonnancement des listes 

A chaque fois que Drupal propose des listes pour 
lesquelles il est utile de pouvoir changer I'ordre 
des elements, un mecanisme JavaScript permet 
d'effectuer cette operation de maniere interactive. 
Ce comportement est signale par des symboles en 
forme de croix qui se trouvent en debut de chaque 
ligne et n'est disponible que si JavaScript est active 
sur votre navigateur. 

Par une manipulation dassique de glisser-deposer 
sur ces croix, il est ainsi possible de changer I'ordre 
des elements de la liste. Faites cependant atten- 
tion, ces modifications ne sont pas prises en 
compte tant que vous n'avez pas clique sur le 
bouton Enregistrer de la page en cours. 


Dans cette liste, il est possible de changer la Description qui par defaut est 
le nom du fichier. Si vous laissez la case a cocher de la colonne Liste 
activee, cette description sera utilisee dans la liste des attachements qui 
sera presentee au lecteur de l’article. La case decochee, le document lui 
sera invisible. 


Modules MAGIQUES Des dossiers parametrables pour les fichiers attaches 

Par defaut, Drupal stocke les fichiers dans le dossier sites/default/files. Ce n'est 
pas un probleme si vous avez peu de fichiers mais cela devient vite genant lorsque ces der- 
niers se multiplient. 

Le module Upload Path vous permet de specifier vous-meme le chemin de sauvegarde en utili- 
sant des variables. II est ainsi possible de specifier le chemin [ni d] qui permettra le stockage 
des fichiers dans un sous-dossier NID du dossier f i 1 es. Le NID etant I'identifiant unique du 
contenu, nous aurons done un dossier par contenu contenant I'ensemble des attachements de 
ce contenu. 

Faites cependant attention au parametre Clean file upload filenames, qui implique le 
renommage du fichier avant ecriture sur le disque. Decochez cette case pour garder le meme 
nom de fichier que celui d'origine. 

► http://drupal.org/project/uploadpath 


Organisation des fichiers attaches 


Supprimer 

Liste 

Description 

Taille 

* 

□ 

0 

| La copie d£cran 

1 05.4 


* 

http:i7www.colc hicf-jp-coTEal . Iivsi Les.'dsfaiJ 1/ files:' cope decranJD.png 

Ko 

Bon Asavoir Utiliser les fichiers attaches 

* 

□ 

0 

|Le manuel utilisateurj 

274.03 

dans les contenus 


http:,’ .'www .cdc Hqje-ccnaa'l .tT.'si tes/detad Hiss.' Mamet utiliBB.teLr.pdt 

Ko 


Si vous decochez la case Liste d'un fichier attache, 
celui-ci sera invisible pour le lecteur. L'interet de 
cette option est de vous permettre d'integrer par 
exemple une image a votre contenu. En effet, en 
attachant un fichier mon_i mage . png, vous 
constatez que son adresse est http://mon_site/ 
files/monjmage.png. II est done possible de 
mettre dans le corps de Particle une balise HTML 
comme ceci : 

<i mg s rc="http : //mon_si te/f i 1 es/ 
mon_image.png"> 


Les modifications realisees sur cette table ne seronten registries que lorsque le formulaire 
sera soumis. 


Enfin, si vous desirez supprimer le fichier attache, cochez simplement la 
case correspondante dans la colonne Supprimer. Le fichier sera effective- 
ment efface des que nous enregistrerons farticle. 


130 


www.frenchpdf.com 


Apercu avant sauvegarde 

Notre article redige, nous avons la possibility de le previsualiser avant 
publication en cliquant sur le bouton Apergu. Devrait alors apparaitre le 
meme formulaire, precede du rendu final de farticle en version abregee 
et en version complete. 

Vous pouvez encore modifier le texte, le formulaire de saisie etant place 
juste en dessous de f aper^u. 


Apergu de la version abregee 

Mon premier article 

8 juillet 2009 - 1 1 :10am — Marine 
Geci est I 'introduction de mon article 

Apergu de la version complete 

Mon premier article 

8 juillet 2009 - 1 1 :10am — Marine 
Geci est I 'introduction de mon article 

Et ceci est son developpement... 

Taille 

1 05.4 Ko 
274.03 Ko 


Fie hie r attache 

La copie dlecran 
Le manuel utilisateur 


Figure 7-24 

Apercu de farticle 


Comme vous le voyez, notre fichier attache est bien present dans la liste 
en dessous de farticle dans sa forme complete et lutilisateur peut le tele- 
charger en cliquant sur le lien correspondant. 

Enregistrement de Particle 

Lorsque vous jugerez votre article satisfaisant, vous pourrez appuyer sur 
le bouton Enregistrer. Devrait alors apparaitre la version longue de 
farticle precede dun message de Drupal vous indiquant que le contenu a 
bien ete cree dans la base de donnees. 

En haut de farticle se trouve son titre, suivi de deux onglets Voir et Modi' 
fier. Un clic sur le bouton Modifier aura pour effet de vous renvoyer dans 
le formulaire precedent, vous permettant ainsi d’en modifier le contenu. 


Modules magiques 

Eviter de se marcher sur les pieds 

Si un autre contributeur modifie avant vous un 
contenu que vous decidez a votre tour de modifier 
avant que ce dernier n'ait eu le temps d'enregis- 
trer, vos modifications seront rejetees par Drupal 
qui vous indiquera que le contenu a change entre 
le moment de I'edition et celui de I'enregistre- 
ment. Vos modifications seront done perdues. Pour 
eviter cela, vous pouvez utiliser le module Check- 
out qui va verrouiller les modifications sur un con- 
tenu de maniere a ce que les modifications par 
d'autres utilisateurs soient rejetees des le debut. 
Lorsque vous sauvegarderez le contenu, il sera 
automatiquement deverrouille. Ce module est 
indispensable pour le travail en equipe. 

► http://drupal.org/project/checkout 
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Mon premier article 


Modifier 


£ 


Le ca rite nu 'Mon premier article', de type 'Article', aete cnee. 


8 JUilldt 2009 - 11:1 1am — Marina 
Ceci est I 'Introduction de non article 

Et ceci est son developpe merit... 


Taille 

105.4 Ko 
274.03 Ko 

Figure 7-25 

[.'article en version complete A J outer un commentaire 


Fichier attache 

La copie d'ecran 
Le man ue I utilisateur 


Bon a savoir 

Qui a le droit de modifier un article 

Les boutons Voir et Modifier ne sont visibles que 
pour les utilisateurs ayant le droit de modification 
sur I'artide, c'est-a-dire son auteur et I'administra- 
teur du site. De maniere generate, ces utilisateurs 
peuvent etre I'auteur de I'artide dont le role dis- 
pose du droit Modifier ses propres articles, et 
tous les utilisateurs beneficiant du droit Modifier 
les articles. 


En bas de I’artide s’affiche une zone de liens, qui pour l’instant n’en 
compte qu’un seul : Ajouter un commentaire. Ce lien sera utilise par vos 
visiteurs pour commenter votre article. 

Enfin, le corps de l’article est surmonte d’un en-tete indiquant sa date de 
creation, suivi du nom de l’utilisateur qui l’aura cree. 

Notre billet est enregistre, mais comme nous avons parametre notre type 
de contenu Article sans l’option de mise en ligne automatique, il n’est 
pour l’instant visible que par 1’Administrateur (qui a tous les droits) et 
par Marine (qui en est I’auteur). C’est ce que signifie ce fond rouge. 
Vous pouvez vous deconnecter pour verifier en tant que visiteur ano- 
nyme la non-visibilite de ce billet. 


Noeuds, chemin interne et alias 

Si vous regardez l’URL affichee dans la barre d’adresse de votre naviga- 
teur, vous constatez qu’elle est de la forme http://www.colchique-conseil.fr/node/1 . 
Si on ecarte l’adresse du site lui-meme, reste ce que Drupal appelle le 
chemin interne de la page : node/1. 


Figure 7-26 

Le chemin interne de I'artide 


htt p ://winw . c ole h iqu e-c on s ei I , f r/n ode'' 1 


Toute page de Drupal a un chemin interne. Par exemple, le chemin 
interne lorsque vous ajoutez un nouveau contenu est node/add, celui 
pour afficher l’administration est admin, celui pour la configuration du 
site admin/build, et ainsi de suite. Pour revenir a notre contenu, node/1 
signifie le « noeud ayant pour identifiant 1 ». 
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Un noeud pour Drupal (en anglais node) est un contenu au sens large du 
terme. Ici node/1 est notre article. 

Si vous cliquez sur le bouton Modifier de la page, vous constaterez que le 
chemin change en node/l/edit. Ce chemin signifie que nous sommes en 
train d’editer (en anglais edit) le noeud ayant pour identifiant 1. 

Certains peuvent considerer qu’un article ayant pour chemin node/1 
n est pas tres explicite pour lutilisateur et prefereraient que l’URL soit 
http://www.colchique-conseil.fr/mon_premier_article. C’est sans aucun doute une 
question de gout, mais Drupal respecte ceux de chacun : il vous offre la 
possibility de definir (ou de redefinir) des alias sur les chemins, en vous 
permettant de creer les URL de votre choix. Ce fonctionnement est gere 
par le module Path que nous avons active en debut d’ouvrage. 

Creer un alias sur le chemin de notre article se fait tres simplement en 
descendant dans la section Parametres du chemin d'URL. Vous pouvez ici 
taper le chemin de votre choix. Ne perdez pas de vue que ceci est un 
chemin : il doit en consequence ne contenir que des lettres et des chiffres 
sans accents, et certains caracteres sont interdits (?, &, # par exemple). 


Parametnes du chemin d'URL 


| mo n_p tie m ie r_artie le 

SpecifieroptionnellemenL une URL alternative par bquelle cette tee 
Utilieerun chemin lelatiFet ne pasajouterde slash Final ou Taliaad't 


Figure 7-27 

Definition d'un alias sur I'artide 


En enregistrant le contenu (sans oublier de saisir un petit message expli- 
catif de votre action dans le journal), vous constaterez que le chemin de 
I’artide et son URL ont change, affichant ainsi notre alias. 


| S3 http ://w ww.colchique-conseil.fr/mon_premier_article 


Figure 7-28 

Le chemin lisible de I'artide 


Toutefois, si vous tapez a la main dans la barre d’adresse de votre naviga- 
teur TURL http://www.colchique-conseil.fr/node/1, vous constaterez que votre 
contenu reste disponible depuis l’ancien chemin. Ce chemin, toujours 
valide quel que soit Y alias que vous deciderez de lui affecter, est appele per- 
malien ( permalink en anglais), ou encore « chemin interne » de Drupal. 

Pour mieux comprendre comment tout ceci fonctionne, redevenons 
Administrateur et dirigeons-nous vers Construction du site > Alias d'URL. 

Nous retrouvons ici l’alias que nous venons de creer. Vous pouvez le 
modifier ou le supprimer. En cliquant sur Ajouter un alias , vous pouvez 
aussi en creer de nouveaux. Le tout est de connaitre le chemin interne de 
la page que vous cherchez a lier et ensuite de saisir l’alias de votre choix. 


Attention Les alias sont des choses 
changeantes 

Si vous communiquez I'URL d'un article sur le 
Web, pensez toujours a donner son permalien et 
jamais un alias. Car un alias peut etre change 
tres facilement et votre lien serait des lors inuti- 
lisable. Ne communiquez un chemin avec alias 
que lorsque vous etes certain qu'il ne changera 

iamaic 
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I Filtre | 


Figure 7-29 

La liste des alias 


A lias ^ 

mo n_p re m ie r_artic le 


Systeme 

Lang us 

Operations 


node/1 

Frangais 

modifier 

supprimer 


Modules magiques 

Creation automatisee d'alias 


Notez que vous pouvez avoir plusieurs alias pour un meme chemin 
interne. 


Le module contribution Pathauto permet de 
generer automatiquement les alias en fonction de 
divers elements comme le titre de Particle, la date, 
le nom de I'auteur, etc. 

Attention a I'utilisation de la date dans I'alias d'un 
article, car cet alias changera a chaque fois que 
vous modifierez Particle, ce qui peut rendre le refe- 
rencement problematique. Choisissez la nomencla- 
ture la plus stable possible, comme le titre de 
Particle seulement. 

► http://drupal.org/project/pathauto 


Pour finir sur les alias, il est important de bien comprendre que lorsque 
vous utilisez cette fonctionnalite, vous obligez Drupal a rechercher dans 
une table en base de donnees les alias pour un chemin interne donne, ce 
qui aura un impact sur les performances. Pour un site a fort trafic, veillez 
a bien mesurer cet impact en termes de vitesse avant de generaliser 
l’usage des alias. 


Administration des contenus 


Publication de Particle 

II est temps a present de rendre notre contenu visible a tous, et cela con- 
siste a modifier le statut du contenu pour le passer de non publie a publie 
et promu en page d'accueil. 

Pour effectuer cette tache, reconnectons-nous avec la casquette Admi- 
nistrates, avant de nous diriger une fois de plus vers Administrer > Ges- 
tion du contenu > Contenu. Nous arrivons ainsi sur une page qui rappelle 
dans sa structure la Gestion des utilisateurs. 

Comme pour cette derniere, cette page permet d’effectuer des actions de 
masse sur un ensemble de contenus. Nous pouvons ainsi filtrer les con- 
tenus suivant un statut donne ( publies , non publies , promus en page 
d'accueil , etc.), un type de contenu donne (Article, Page, etc.). 

Nous y retrouvons une zone de filtrage, une zone d’actions et une liste de 
contenus pour finstant reduite a notre seule production. 


Figure 7-30 

La liste des articles du site 


□ 

Titre 

Type 

Auteur 

Statut 

Langue 

Operations 

□ 

Mon premier article 

Article 

Marine 

non 

publie 

Independant 

de la langue 

editer 
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Sur cette ligne apparaissent des notions connues telles que Titre, Type (de 
contenu) et Auteur. Nous constatons egalement que l’article est non publie, 
ce qui correspond bien au parametrage defini pour ce type de contenu. 

Dans la section de mise a jour, nous retrouvons la possibility de sup- 
primer des contenus mais aussi d’en changer le statut. Nous pourrions 
done tres facilement publier notre article en le cochant et en selection- 
nant Taction Publier , puis en appuyant sur Mise a jour. 

Mais il est plus interessant pour notre apprentissage de cliquer sur le lien 
editer afin de retrouver le formulaire d’edition de contenu que nous con- 
naissons, affiche cette fois-ci au complet et sans limitations car vous etes 
dans le role Administrateur. 

Pour Tessentiel, il s’agit bien du meme formulaire, comportant juste des 
sections supplementaires. Certaines de ces sections sont familieres, car il 
s’agit des memes options dont nous avons defini les valeurs par defaut 
lors du parametrage du type de contenu : Parametres des commentates et 
Options de publication. Si nous modifions dans le cas present ces valeurs 
par defaut, elles s’appliqueront pour ce seul contenu uniquement. 

Pour publier notre article, il nous suffit d’etendre la section Options de 
publication et de cocher Publie et Promu en page d'accueil avant d’enregis- 
trer le contenu. Notre article est done maintenant en ligne et present en 
page d’accueil. 


Retour a la page d’accueil 

Par defaut, Drupal affiche sur la page d’accueil du site la liste des con- 
tenus classes du plus recent au plus ancien. Notre premier article etant a 
present publie, nous pouvons verifier qu’il est bien visible a cet endroit 
strategique du site. Pour effectuer cette verification, le mieux est de se 
deconnecter completement, de maniere a voir le site tel que le visiteur le 
verra, et de cliquer en haut de la page sur le lien Accueil. 


Accueil * Admin istrer > Gostion du contenu 


Figure 7-31 

Retour a la page d'accueil par le fil d'Ariane 
(en anglais, breadcrumbs) 


Nous void done renvoyes a la page d’accueil, qui n’est plus la page de bien- 
venue que nous avions decouverte lors de Installation de Drupal, mais bel 
et bien la liste de nos contenus, n’affichant pour l’instant qu’un seul article. 
Deconnectons-nous pour verifier ce que voit le visiteur anonyme. 
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Colchique Car chaque brin d'herbe est unique... 


I 


Connexion utilisateur 

Norn d' utilisateur : 


Mot de passe : 


Mon premier article 

8 juifet 3009 - 11:1 1am — Marine 
Ceci est I 'introduction de mon article 

Ajo Lite r u n co m me ntai re E n s avo ir plus 2 f ic h ie rs attac he s 


Se connecter 
Crier un nouveau compte 
Demander un nouveau motde 
passe 


m 


Figure 7-32 La version page de garde de notre site avec notre premier article 

Nous retrouvons ici le resume de notre article, sa date de creation, les infor- 
mations sur son auteur et le lien pour ajouter un commentaire. Au regard 
de la vue precedente, les nouveautes sont le lien En savoir plus qui pointe sur 
la version complete de farticle, et 2 fichiers attaches donnant acces aux 
fichiers que nous avons transferes dans le contenu. Cliquons maintenant 
sur En savoir plus pour decouvrir farticle dans sa version complete. 


Colchique Car chaque brin d'herbe est unique... 



Connexion utilisateur 

Nonn d' utilisateur : 


Mot de passe : 


Se connecter 
Greer un nouveau compte 
Demander un nouveau motde 
passe 


Mon premier article 

8 juillet 2009 - 11:11am — Marine 
Ceci est I 'introduction de mon article 

Et ceci est son developpement... 

Fic hie r attac lie 

Lacopie d'ecran 
Le man ue I utilisateur 


Taille 

1 05.4 Ko 
274.03 Ko 


Ajouter un commentaire 


Figure 7-33 L’artide en version complete 
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Supprimer un article 

Si un contenu ne vous convient plus, il vous est evidemment possible de 
le supprimer. Pour cela, en etant Administrateur ou Tauteur du contenu, 
il suffit de cliquer sur Modifier , puis en bas du formulaire sur Supprimer. 
Apres confirmation, le contenu sera definitivement detruit avec tous les 
fichiers et les commentaires qui auraient pu y etre attaches. 

Notez qu il est aussi possible de retirer le statut publie dun article si vous 
desirez juste le rendre invisible pour les visiteurs. 


MODULES MAGIQUES Deplacer un article 

II arrive parfois qu'on ait a regrouper deux articles en un seul. Generalement, il suffit de reco- 
pier le contenu du second article a la suite du premier, de mettre en forme, de I'enregistrer, 
puis de supprimer I'article en trop. 

Le probleme qui se pose alors est que vos visiteurs ont peut-etre mis dans leur liste de 
marque-pages I'adresse de I'article desormais disparu. Ou alors, cet article a ete mis en refe- 
rence sur un autre site et son URL amene done a une erreur « 404 Document non trouve ». 

La solution consiste a utiliser le module Path Redirect qui va vous permettre d'ajouter 
I'adresse de I'article supprime et de lui associer celle de I'article fusionne. L'utilisateur qui arri- 
vera sur I'ancienne adresse sera alors automatiquement redirige sur la nouvelle. 

► http://drupal.org/project/path_redirect 

Une autre option est d'utiliser le module Search 404 qui va tout simplement transformer un 
chemin introuvable en un resultat de recherche, permettant ainsi de retrouver le contenu 
perdu. Attention, cependant, car cela ne fonctionne bien que si vous avez utilise des alias sur 
vos chemins, et dans tous les cas, cela peut generer une plus forte charge sur vos serveurs si 
vous avez beaucoup de pages « non trouvees ». 

► http://drupal.org/project/search404 


Les commentaires 


Ajout d’un commentaire 

Nous avons passe du temps a parametrer les commentaires pour le type de 
contenu Article, il est maintenant temps d en voir le resultat. Pour cela, le 
mieux est de se placer dans la peau dun visiteur anonyme. Deconnectez- 
vous de votre compte, et dirigez-vous vers la page d’accueil. 


Ajo Liter un commentaire En savoir plus 1 fichier attache 


Ajouter un nouveau commentaire a cette page. 


Figure 7-34 

Lien d'ajout d'un nouveau commentaire 


Le visiteur peut commenter farticle par le lien Ajouter un commentaire 
present a la fin du texte, que ce soit dans sa forme abregee ou sa forme 
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Figure 7-35 

Le formulaire de commentaire 
pour les utilisateurs anonymes 


complete obtenue apres avoir clique sur le lien En savoir plus. Ceci 
femmenera sur un ecran vierge de saisie, puisque nous avons parametre 
le systeme pour afficher le formulaire sur une nouvelle page. 

Repondre 

Votre nom : * 

[Roberto ] 

Adresse electronique : * 



Le conte nu de ce champ sera, maintenu prive et ne sera pas affbhe publiquement. 

Page d'accueil : 

[http://roberto.com ] 

Commentaire : * 

Article passionnant mais manquant neanmoins un peu de substance. 


Dans ce formulaire, le visiteur anonyme pourra saisir son nom (ou pseudo), 
son adresse courriel (que nous avons rendue obligatoire dans les parame- 
trages), sa page web (optionnelle) et bien evidemment son commentaire. 

Puisque nous avons rendu obligatoire faperfu du commentaire avant publi- 
cation, notre utilisateur na d’autre choix que de finir par le bouton Apergu. 

Apercu 

Arti C I e p as S i □ n n ant m ai S 8 ju illst 2000 - 1 2:02pm - Roberto ( non verif is) 

Figure 7—36 Article passionnant mais manquant neanmoins un peu de substance. 

L'apergj du commentaire 


Le visiteur a done encore la possibilite de modifier son commentaire 
avant de finalement cliquer sur Enregistrer. Le commentaire apparait 
alors en bas de farticle. 


Commentaires 

Arti cle passi onnant mai S 8 \ um 2009 - 1 2:03pm — Roberto (non verity 

Article passionnant mais manquant neanmoins un peu de substance. 

Figure 7-37 

Le commentaire une fois publie repondre 


Figure 7-38 

Indication des commentaires 
presents et encore non lus 


Si Marine se reconnecte, les liens sous la forme abregee de farticle en page 
d’accueil ont alors change, lui indiquant qu un commentaire est present. 


1 commentaire 1 nouveau commentaire En savoir plus 
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Reponse aux commentaires 

Marine a alors la possibilite de visualiser le commentaire et bien evide- 
ment d y repondre en cliquant sur le lien repondre. 

Commentaires 

Arti cle passionn ant m ai s n° u a ju niet 2009 - 1 2:02pm — Roberto ( non vertt e) 

Article passionn ant mais manquant neanmoins un peu de substance. 

Figure 7-39 

repondre Le lien de reponse a un commentaire 


Le formulaire de Marine, qui est une utilisatrice authentifiee, contient 
moins de champs que celui du visiteur anonyme. En effet, Marine a la 
possibilite de modifier dans le menu Mon compte sa page web, et son 
adresse courriel est deja connue du systeme. 

Repondre au commentaire 

Arti C I e p as S i 0 n n ant m ai S e ju mat 2009 - 1 2:02pm — Roberto { non verif £) 

Article passionn ant mais manquant neanmoins un peu de substance. 


Repondre 

Votre nom : 

Marine 


Modules magiques 

Faire de la bouture de commentaires 

Beaucoup d'utilisateurs, lorsqu'ils desirent 
repondre a un commentaire, se trompent et di- 
quent sur le lien ajouter un commentaire au 
lieu de repondre. Du coup, les commentaires ne 
sont plus affiches de maniere decales et les con- 
versations deviennent plus difficiles a suivre. 

La solution est un module appele Comment mover, 
qui permet de replacer les commentaires dans le 
bon ordre. Faites cependant attention, ce module 
est pour I'instant a I'etat « instable » et il faudra 
attendre la version « stable » pour I'utiliser en pro- 
duction. 

► http://drupal.org/project/comment_mover 


Commentaire : 

Merci avous, je vais encore un peu I'ameliorer... | 


Figure 7-40 

Le formulaire de commentaire 
pour un utilisateur identifie 


En revanche, comme nous 1’avons vu, Marine est obligee dutiliser le 
bouton Aperfu avant de pouvoir Enregistrer sa reponse. 


Commentaires 

Article passionnant mais S juillet SCOS - 12:02pm — Roberto (non verifie) 

Article passionnant mais manquant neanmoins un peu de substance, 
supprimer editer repondre 


Merci a VOUS, je vais encore Nouveau S juillst 2009 - 12 ; 04 pm — Marine 
Merci avous, je vais encore un peu I'ameliorer... 

Figure 7-41 

supprimer editer repondre 

La reponse une fois publiee 
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Parce que nous avons choisi le mode Par Discussion - deplie , l’affichage 
du nouveau commentaire de Marine apparait sous celui du visiteur, 
decale d’un cran vers la droite. 

Administration des commentaires 

Tout ceci est pour le moment parfait, mais voyons ce qui se passe 
lorsqu’un mauvais esprit se mele a la partie. 

Imaginons done un nouveau visiteur qui lui aussi poste un commentaire, 
mais un peu moins constructif. 


Ameliorer ne suffira jamais, Bjuiibt ara- 1207pm— zorgiub (non vfirifBj 

Ameliorer ne suffira jamais, votre article est juste mauvais, vous aussi, et je ne parle meme 
_. _ . . pas des pathetiques commentaires !!! 

Figure 7-42 

Un commentaire de troll re pond re 

Ce genre de commentaires n’apporte pas grand-chose au sujet et na 
qu un objectif : mettre le bazar dans le fil de discussion. C’est ce qu on 
appelle un troll (voir l’aparte page suivante). C’est a l’administrateur ici 
d’intervenir. 

Pour gerer les commentaires douteux, l’administrateur dispose d’un outil 
efficace disponible dans Gestion des contenus > Commentaires. 

Options de mise a jour 

| Retirer les commentaires se lectio nnes 0 1 1 Mise a jour j 



□ 

Objet 

Auteur 

Poste sur 

Date'*' 

Operations 


m 

Ameliorer ne 

suffira jamais. 

Zorglub 
(non verifie) 

Mon 

premier 

article 

0 8/07/2 0 09 - 

1 2l07 

editer 


□ 

Menci a vous, je 

vais encore 

Marine 

Mon 

premier 

article 

08/07/2009 - 

12:04 

editer 

Figure 7-43 

Administration des commentaires 

□ 

Article 

passionnant 

mais 

Roberto 

(non verifie) 

Mon 

premier 

article 

08/07/2009 - 

12:03 

editer 


Cette page vous permet de lister l’ensemble des commentaires et d’effec- 
tuer des actions sur une selection. Nous allons ici pouvoir Supprimer le 
commentaire ou Retirer le commentraire indelicat que nous aurons preala- 
blement selectionne. 
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Culture Trolls des villes et trolls des montagnes 


Ce type de contributeur indelicat est communement appele un troll. Cette famille de nuisibles 
existe depuis la naissance meme de I'lnternet, de quand date cette appellation. Son seul 
objectif est de passer le temps en montant les contributeurs les uns contre les autres. Vous 
avez plusieurs manieres de gerer ce genre de specimen avant de passer au stade ultime de la 
destruction massive : 

• Tout d'abord, une critique - meme exprimee avec un manque de civisme caracterise - n'est 
pas forcement un troll. Analysez bien a froid le commentaire avant de le supprimer, car 
supprimer une critique constructive est risque pour I'image de votre site. 

• Utilisez la regie « si tu me cherches, tu ne me trouves pas », et surtout ne rentrez jamais 
dans le jeu d'un troll. La regie ancestrale sur ce point est le fameux « Don't feed the 
troll » (ne nourrissez pas le troll). Ignorez-le tout simplement et le troll degu s'ennuiera 
avant d'aller troller ailleurs. 

• Si vous devez repondre, ne gardez que ce qu'il y a de positif dans le commentaire du troll et 
ignorez le reste. 

• Si la conversation s'emballe et que les autres contributeurs sont pris a parti, n'hesitez pas a 
bloquer le troll en utilisant les regies d'acces vu au chapitre precedent. Vous pouvez aussi 
termer la conversation en passant les commentaires en lecture seule. Mais ceci risque de 
ne pas etre apprecie par les non-trolls ; a utiliser avec prudence done, et toujours en pre- 
venant prealablement de votre demarche via un commentaire explicatif. 

Pour plus d'information sur la trollogie (la science d'etude des trolls), veuillez vous referer a 
I'adresse suivante : 

► http://uzine.net/article1 032.html 


Lorsque vous retirez un commentaire, il sera non pas detruit, mais place 
en file d'approbation. C'est un bon moyen de temporiser une attaque de 
troll sans etre aussi definitif qu une suppression. Nous allons done appli- 
quer cette action et voir ce qui en decoule. 

Tout d'abord, cliquez sur l'onglet File d’attente d’approbation. Vous 
retrouvez ici une liste identique a la precedente, mais ne contenant que 
les commentaires non publies, celui de notre troll pour l'instant. Nous 
disposons ici aussi d'actions sur la selection permettant soit de republier, 
soit de supprimer definitivement. 

Avant de supprimer ce commentaire, refaisons un tour sur l'article pour 
voir comment apparait pour l'administrateur un commentaire non 
publie. Vous remarquez aussitot que le nombre de commentaires pour 
notre article est repasse a deux. Enfin, vous constaterez que le commen- 
taire « depublie » est toujours visible, mais avec cette fois un fond rouge. 

Vous pouvez vous deconnecter pour constater que le commentaire non publie 
nest effectivement visible que pour ladministrateur. Ce constat fait, vous avez 
maintenant tout ce quil faut pour detruire definitivement ce commentaire. 
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Merci a yous, je vais encore 

Merci a vo us, je vais encore un pen I 'ameliorer... 


8 juillet 2000 - 1 2:04pm — Marine 


£ 


supprimer editer repondre 


Figure 7-44 

Le fond rouge indique 
que I'article n'est pas publie 
et qu'il est en file d'approbation. 


Ameliorer ne suffi ra B juNOt 3009 - 1 2:07pm — Zonglub (non verifB) 

jamais, 

Ameliorer ne suffira jamais, votre article est juste mauvais. vous aussi, et je 
ne parle mime pas des pathetiques commentaires HI 

supprimer editer repondre 


Les formats d’entree 

Les formats d’entree sont une chose assez mal nommee. En realite, la 
bonne expression devrait etre « format du texte » car il s’agit en realite de 
definir la syntaxe utilisee pour saisir I’article ou, de maniere plus gene- 
rale, des transformations a effectuer sur ce texte pour en obtenir une ver- 
sion XHTML. 


Figure 7-45 

Modification de notre premier article 


Fonctionnement d’un format d’entree 

Nous allons a present modifier I’article que nous venons de creer en cli- 
quant sur son lien modifier pour le rendre plus presentable. 

Corps : 

Bienvenue sur le site Colchique. le cabinet de conseil en nessources humaines qui a I'ethique au 
fond dii coeur. 


Vous trauverez sur notre site une presentation complete, des ses intervenants etde <b>ses 
valeurs</b>. 

Vous pourrez aussi decouvrir nos publications ainsi que nos billets d'humeur, 

Bonne visite 

Lliq u i pe http ://www ,ca Ich iq ue-co n se i .fr/ 


Avant de valider, pretez attention au texte qui se situe juste en dessous de 
la zone d’edition : 


Figure 7-46 

Aide sur le format d'entree actif 


Les adressesde pages web etde messagerie electron ique sont transformees en liens automatiquement. 
Tags HTMLautorises : <a> <em> <strong> <cite> <code> <ut><ol> <lt> <dt><dt> <dd> 

Les ligneset les parag raphes wont a la ligne automatiquement. 
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Nous y apprenons que les passages a la ligne seront transformes automa- 
tiquement en paragraphes, que les adresses courriel et les liens web 
seront rendus cliquables et que seules les balises listees sont autorisees. 

Une fois le contenu saisi, enregistrez-le. Le resultat devrait ressembler a 
cela : 


3 juillst 3009 - 11:1 1am — Marine 

Bienvenue sur le site Colchique, le cabinet de conseil en nessounces humaines qui a Hethique au fond du 
coeur. 


Vous trouverez sur notre site une presentation complete, des ses intervenants etde ses valeurs. 
Vous pourrez aussi decouvrir nos publications ainsi que nos billets d'humeur. 

Bonne visite 

Lleq u i pe http :.'Vwww .co Ic h iq ue-co n se i .f r/ 


Figure 7-47 

L'artide une fois publie 


Comme vous le voyez, les sauts de lignes sont correctement respectes, ce 
qui indique que des balises XHTML <px/p> ont ete ajoutes. De meme, 
l’adresse du site est devenue un lien. En revanche, la balise de mise en 
gras <b> a ete eliminee, ce qui est logique puisqu’elle ne fait pas partie 
des balises autorisees. 

Cet ensemble de regies de transformation constitue ce qui est appele un 
« format d’entree », a comprendre comme « regies de formatage appli- 
quees aux contenus saisis en entree », la « sortie » etant du code 
XHTML. Nous pouvons verifier cela en utilisant le clic droit de notre 
navigateur et en selectionnant dans le menu contextuel l’option Code 
source de la page. 

<P> 

Vous trouverez sur notre site une presentation complete de la societe, de ses intervenants et de 
ses valeurs. 

</p> 

<P> 

Vous pourrez aussi y decouvrir nos publications ainsi que nos billets d’humeur. 

</p> 

<p>Bonne visite</p> 

<P> 

L’equipe de 

<a href="http://www.colchique-conseil . f r" ti tl e="http : //www. col chi que-consei 1 . fr"> 
http : //www . col chi que-consei 1 . f r 
</a> 

</p> 

Comme vous le constatez, notre simple texte a done bien ete transforme 
en code XHTML valide par le format d’entree. 
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De prime abord, ce format apparait efficace et bien adapte a des contri- 
buteurs qui ne connaissent pas le XHTML. Mais il peut sembler res- 
trictif pour qui desire un plus grand degre de liberte. Comme souvent 
avec Drupal, il ne s’agit la que de la vision par defaut, le systeme de for- 
mats d’entree pouvant aller bien au-dela de ces simples transformations. 

Configuration d’un format d’entree 

Pour comprendre comment tout ceci fonctionne, redevenons Adminis- 
trates et rendons-nous dans la Configuration du site puis dans Formats 
d'entree. 


Nom 

Roles 

Ope ratio re 

Filtered 

Tous les roles peuvent utiliser 

configurer 

HTML 

ce format 


Aucun role ne peut utiliser ce 


Full HTML 

configurer 

format 


Figure 7-48 

La liste des formats d'entree 


Definir le format par defaut 


Nous trouvons ici les deux formats d’entree connus de Drupal, avec 
Filtered FITML comme format par defaut. Dans la colonne Roles , nous 
voyons qu’un format d’entree peut etre limite a certains roles seulement. 
Le format d’entree Filtered HTML etant defini par defaut pour tous les 
roles, c’est done celui qui est utilise depuis le debut. Cliquons sur son 
lien configurer pour voir ce qui se cache derriere. 

Nous retrouvons sur cette page le nom du format, suivi de la liste des 
roles qui ont le droit de l’utiliser. S’agissant d’un format fondamental, il 
est impossible de modifier ces choix car il doit rester accessible a tous. 


Mom : 

| Filtered HTML 

Entiez un nom unique pource formal d'enliee 
Roles 

Tous Iss roles pour Iq format par defaut doh/ent&tro actives. 
/ uti 1 1 s ate u r ano ny me 
V utilisateur identifie 

Figure 7—49 ~ contributeur 

Les roles autorises a utiliser un format 
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Dans la section suivante, nous avons l’ensemble des regies de filtrage qui 
composent notre format. 


i 

r^. 

Filtnes 

Choeissez los filtres qui seront utilises dans ce format d'entree. 

0 Convertisseurde sautde ligne 
Converts lea suta de lignea en HTML (c'eat a dire en balbea <br> et <p>). 

0 Cornecteur HTML 

Corrects faulty and chopped off HTML in poatinga. 

0 filtne HTML 

Allows you to restrict whether uaeia can poat HTML and which taga to filter out. It will afeo 
remove hamifu I content auch aa JavaScrpt eventa, JavaScrpt UR La and CSS atylea from thoae 
taga that are not removed. 

0 filtne URL 

Tranefbrme lea adie^ea web et e-mail en liens cliquables. FlCJUrC 7 — 50 

La liste des filtres entrant dans la composition du format d'entree 


Nous retrouvons ici les regies qui nous ont ete exposees lors de l’edition 
du contenu : 

• Convertisseur de saut de ligne est le filtre qui transforme les retours 
chariot en balises <br/> et <px/p> ; 

• Correcteur HTML corrige (legerement) le code HTML mal ecrit ; 

• Filtre HTML empeche l’utilisation de certaines balises non compatibles 
XHTML (comme <b> ou <i>) ou dangereuses pour le site, comme 
<script> qui permettrait au contributeur de rajouter du JavaScript 
dans les contenus ; 

• Filtre URL est quant a lui responsable de la transformation des adresses 
web et courriel en leur version XHTML cliquable. 

Nous avons done la un filtrage parfait pour des commentaires, car tres 
restrictif et ne laissant au visiteur mal intentionne ou etourdi que peu de 
possibilites de commettre des erreurs graves pour le site. Cependant, si 
l’application de certains filtres ne vous convient pas, vous avez bien sur la 
possibilite de les decocher ; apres enregistrement de la configuration, ils 
ne seront plus utilises. 

Certains filtres sont parametrables. Pour avoir acces a leur configuration, 
vous devez cliquer sur fonglet Configurer. Apparait alors un formulaire 
permettant de determiner la longueur maximale des liens pour le filtre 
URL, ou encore la liste des balises autorisees pour le filtre HTML. Vous 
pouvez par exemple decider d’ajouter la balise <b> (attention, le code 
genere ne sera des lors plus certifie XHTML). Des que vous aurez enre- 
gistre la configuration, les nouveaux reglages seront actifs, y compris 
pour les contenus deja crees. 
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Bon A SAVOIR L'impact sur les performances 
des formats d'entree 

Le format d'entree d'un contenu est applique lors 
du premier affichage de la page. Pour ne pas fabri- 
quer a chaque fois le code XHTML et perdre ainsi 
en performance, Drupal va Stocker le resultat dans 
une table de la base de donnees. Ce genre de table 
est appele un cache. Ainsi, lors du second affi- 
chage et des suivants, c'est la valeur placee en 
cache qui sera utilisee, reduisant d'autant le temps 
de creation de la page. 

Lorsque vous enregistrez des modifications sur un 
format d'entree (activation ou desactivation d'un 
filtre, ordonnancement ou parametrage), Drupal 
va simplement vider la table des caches associee 
aux filtres. Lors du prochain affichage, ce sera 
done le nouveau format qui sera utilise. 


BON A SAVOIR Pas de droits, pas d'edition 

Attention, si vous creez un contenu avec un format 
d'entree donne, seuls les utilisateurs dont le role le 
specifie auront le droit de le modifier, et ce, meme 
si vous avez explicitement ajoute les permissions 
d'edition du type de contenu. Ainsi, dans le cas ou 
vous auriez donne le droit d'edition a un role, mais 
ou un utilisateur ayant ce role ne verrait pas 
I'onglet Modifier, verifiez les droits sur le format 
d'entree qu'utilise le contenu. 


Figure 7-52 

Section permettant de choisir un format 


Enfin, il est important dans certains cas de pouvoir choisir l’ordre dans 
lequel les filtres sont executes. Cest le role de I’onglet Reordonner que 
nous allons etudier un peu plus loin. 

Comme pour les fichiers attaches, il est possible via cette page de posi- 
tionner les filtres les uns par rapport aux autres en faisant du simple 
glisser-deposer. Une fois la configuration enregistree, le nouvel ordon- 
nancement sera actif, y compris pour les conte nus deja crees. 


Droits sur un format d’entree 

En retournant sur la liste des filtres (vous pouvez passer directement par 
le lien Format d'entree qui se trouve en haut de la page), nous decouvrons 
qu’en plus du format d’entree Filtered HTML, il existe le format 
d’entree Full HTML. 

Comme son nom le laisse presager, ce format est beaucoup moins limite que 
le precedent et nest en consequence disponible par defaut que pour le role 
Administrateur. En cliquant sur le lien configurer , nous constatons tout 
d’abord que Filtre HTML est desactive, mais surtout qu’aucun role n’est coche. 

Il peut pourtant etre utile de laisser a nos contributeurs, qui sont des per- 
sonnes de confiance, la possibility d’utiliser un tel format qui leur laissera 
toute liberte pour ecrire des billets directement en XHTML. Pour ce 
faire, il suffit simplement de cocher le role Contributeur et d’enregistrer 
ensuite la modification du format. 


Roles 

ChoBtesez queb robs peuvent utilber 
filtre. 


U utilisateur anonyme 
U uti I i s ate u r ide ntif ie 


contributeur 


Figure 7-51 

Ajout du role Contributeur a ce format 


Il ne reste plus alors qu’a se reconnecter en tant que Marine et a modifier 
le dernier contenu que nous avons cree, pour constater qu’une nouvelle 
section dediee aux formats d’entree est a present disponible en dessous 
de la zone d’edition du corps : 

Format d'entree 


® Filtered HTML 

O Les adesses de pages web et de messagefie elec treri que sent Irare Fcrmees en I era aulcma liquemenl. 
O Tags HT M L autcrises : oem> .:a1rcng> ocite> <coda> <ul> <dl> *sdt> «dd> 

O Les fepes et les paraejaphes vent a la igie automa licpiernent. 

O Full HTML 

O Les adesses de pages web et de messagefie elec Iroriqje sont trare Formees en iere automa Uquement. 
O Les fgnes et les paragaphes vent a la igie automa tiqLiemenL. 
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L'apparition des deux formats est en soit logique, car le role Contribu- 
tes avait deja acces au format d'entree Filtered HTML de maniere 
implicite. Drupal n avait auparavant pas juge utile de faire apparaitre une 
liste de formats, car il n'y avait qu une seule possibility. 

Avec ce deuxieme format disponible, le contributes peut maintenant 
choisir celui qui lui convient le mieux pour un contenu donne. Si nous 
cochons cette fois Full HTML et que nous enregistrons notre contenu, 
nous constatons que le rendu final n est plus exactement le meme : 


S juillet 2009 - 1 1 : 1 1am — Marine 

Bienvenue sur le site Colchique, le cabinet de conseil en ressources humaines qui a 
I'ethique au fond du coeur. 

Vo us trouverez sur notre site une presentation complete, des ses intervenants etde 
ses valeurs. 

Vous pourrez aussi decouvrir nos publications ainsi que nos billets d'humeur. 

Bonne visite Figure 7-53 

Le meme article avec le format d'entree Full HTML 

L 'eq u i pe http ://www ,co Ic h iq ue -co n se i .f r/ 


Lapparition de l'expression « ses valeurs » en gras nous indique que le 
format d'entree ne filtre a present plus cette balise. 

Le format des commentaires 

Les commentaires que saisissent les visiteurs utilisent eux aussi un 
format d'entree. Si la personne qui commente est un anonyme, c'est evi- 
demment le format d'entree Filtered HTML qui sera utilise. Pour cette 
raison, prenez toujours soin de laisser actives les filtres essentiels pour ce 
format (principalement Filtre HTML). 

Si la personne qui commente est un utilisateur identifie, il verra appa- 
raitre en dessous de sa zone de saisie de commentaires la meme section 
Format d'entree que pour la creation d'un contenu. Un contributeur 
pourra done saisir un commentaire sous forme XHTML en selection- 
nant le format d'entree Full HTML 

Le format d’entree PHP 

En activant le module Filtre PHP, un troisieme format d'entree appele 
« PHP code » apparait alors dans la liste des formats. Comme Full 
HTML, ce format n'est par defaut accessible qu'a l'administrateur. Vous 
pouvez cependant autoriser l'utilisation de ce format pour un role parti- 
culier, mais verifiez tres soigneusement ce que vous faites car ce filtre est 
loin d'etre anodin, comme nous allons le voir. 
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URL Module External links filter 

► http://drupal.org/project/elf 


Figure 7-54 

Activation du module External links filter 
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Ce format permet de saisir directement du code PHP dans les contenus en 
utilisant les balises <?php ?>. Cette technique peut paraitre bien pratique 
pour qui maitrise PHP, mais peut aussi bien se reveler tres traitre. En effet, 
dans la hate du developpement d un projet, on a tot fait de coder enorme- 
ment de choses dans ce type de pages notamment des fonctionnalites qui 
auraient davantage leur place dans un module Drupal... 

Linconvenient flagrant est que ce code va devenir tres vite difficile a 
maintenir, a deboguer ou simplement a detecter, pour qui n aura pas rea- 
lise ces pages. 

Lautre inconvenient de taille est que factivation pour un contenu donne de 
ce format d entree desactive implicitement le systeme de cache. De ce fait, 
lutilisation abusive de ce format affectera les performances de votre site. 

Si vous etes amene a lutiliser, n allez jamais plus loin que faffichage de 
variables ou Tappel dune fonction, et n’incluez jamais de boucles ou, 
pire encore, de requetes SQL. 

Ajouter de nouveaux filtres 

A present, vous avez certainement note que les formats sont des compo- 
sitions de filtres et que chacun de ces filtres est lui-meme fourni par un 
module. Ainsi, tous les filtres presents par defaut sont contenus dans le 
module Filter (section Core - obligatoire). En installant les bons modules 
de contribution, vous pourrez done avoir acces a de nouveaux filtres. 

Prenons un exemple concret avec le module External links filter. Ce 
module ajoute un nouveau filtre qui verifie si un lien est interne ou 
externe, et dans le second cas, affiche une petite icone indiquant a lutili- 
sateur qu en cliquant sur ce lien, il sortira de notre site. 


Autre 


Active 

m 

Norn 

Version 

Description 

6. *-2.0 

Adds a CSS ebss to all external and maifto links. 


links filter 



0 

Masquerade 

6. *-1.1 

This module allows permitted users to masquerade as other users. 


Une fois le module installe et active, il est automatiquement present 
dans chacun des formats d’entree existants. Activons-le pour le format 
Full HTML. Comme vous le voyez, le nouveau filtre est bien present. 
Cochez-le et enregistrez le format. 
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0 Gonvertisseurde sautde ligne 
Convertrt les sauts de lignes en HTML (c'eat a dire en balises <br> et <p>). 

0 Correcteur HTML 

Corrects faulty and chopped off HTML in postings. 

® External links filter 
Adds a CSS class to all external and mailto links. 


Figure 7-55 

Ajout du nouveau filtre 
au format Full HTML 


Nom 

filtre URL 


Avant de tester, il nous faut regler un petit probleme. En effet, ce nou- 
veau filtre a besoin d un lien a modifier pour fonctionner. Or, il est pour 
l’instant execute avant Filtre URL. Nous devons done modifier l’ordre 
d’execution des filtres pour placer ce nouveau filtre apres Filtre URL. 

Une fois ce parametrage enregistre, le format est pret a l’usage. Nous 
allons verifier que tout fonctionne correctement en visualisant l’article de 
bienvenue. 


Bonne visite 

Figure 7-57 

L'equipe de http://www.coichique-conseii.fn5i. Le filtre External links filter en action 


Ajouter de nouveaux formats 

Jusqu’a present, nous avons modifie et parametre des formats d’entree 
existants. Il est cependant possible de creer ses propres formats en com- 
posant de maniere inedite les filtres installes. 

Par exemple, il peut etre utile de proposer aux contributeurs une syntaxe 
plus simple que du code HTML pour saisir les conte nus. Il existe pour 
cela plusieurs syntaxes telles que Wiki, phpBB ou encore Markdown. 
Toutes permettent par des annotations simples (par exemple en utilisant 
des * pour definir des listes) de creer un contenu formate. 

Le module Markdown contient un filtre capable de comprendre la syn- 
taxe Markdown que vous pouvez decouvrir sur Wikipedia (http:// 
fr.wikipedia.org/wiki/Markdown). 

Une fois le module installe et active, retournez dans la liste des formats 
d’entree et cliquez sur l’onglet Ajouter un nouveau format. Vous retrouvez 
alors la page maintenant bien connue d’edition des formats. 

Nommez le nouveau format Markdown et cochez le role Contributeur. 
Ensuite, dans la section Filtres , decochez tous les filtres et cochez 
Markdown. 


*£* Gonvertisseurde sautde ligne 
tf* Correcteur HTML 
External links filter’ 


Figure 7-56 

Reordonnancent de I'ordre des filtres 

Bon A savoir 

Pourquoi notre URL est-elle externe ? 

L'icone est bien presente, le filtre a done correcte- 
ment fait son travail. Le fait que le lien sur notre 
page d'accueil soit ici presente comme un lien 
« externe » n'est pas une erreur du module 
External links filter. En effet, ce dernier considere 
que tous les liens commengant http:// sont 
des liens externes. Pour regler ce probleme, nous 
devrions saisir le lien dans le contenu de Particle 
de la maniere suivante : 

<a href=V’> 

www. cochi que-conseil .fr</a> 


URL Module Markdown 

► http://drupal.org/project/markdown 


□ Correcteur HTML 
Corrects faulty and chopped off HTML in posti 

® Markdown 

Allows content to be submitted using Maikdov 


Figure 7-58 

Ajout du filtre Markdown au nouveau format 
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Cliquez sur Enregistrer et le nouveau format est pret a l’emploi. Vous 
pouvez le tester en tant que Marine, par exemple en creant un nouveau 
contenu tel que celui-ci : 


Tltre : 


|Essai d'article en utilisant MarkDown 

1 

Corps : 

] Greer un resume a p art 1 r du curseur | 

Ceci est une **liste** 


* Item 1 


* Item 2 



Format d'entree 


O Filtered HTML 

Q Les sadnesses de pages web et de messagerie electron iq ue sont tra nsformees en liens automatiq uement. 
O Tags HTML autorises : <a> *sm> *strong> <crte> <oode> <ut> <ol> <\t> <dl> <dt> <dd> 

O Les lignes et les parag raphes vont a la ligne automatiq uement. 


Figure 7-59 

Utilisation du nouveau format Markdown 


I® I Markdown 

O You can use Markdown syntax to format and style the text. Also see Markdown Extra for tables, footnotes, and more. 


Dans la section Format d'entree , nous avons maintenant trois choix, dont 
Markdown que nous selectionnons. II ne reste plus a Marine qua enre- 
gistrer pour juger du resultat. 


Modules magiques 

Un format d'entree par type de contenu 


mar, 06/09/2009 - 20:01 — Marine 
Ceci est une lists 


Vous pouvez dans certains cas avoir besoin de 
forcer un format d'entree par defaut pour un type 
de contenu. Cette fonctionnalite n'est malheureu- 
sement pas induse en standard dans Drupal. II est 
cependant possible d'y remedier tres facilement en 
utilisant le module Filter by node type. 

► http://drupal.org/project/filterbynodetype 


Item 1 
Item 2 


Figure 7-60 

Le contenu formate par le filtre Markdown 


Le filtre Markdown a bien joue son role et a transforme notre syntaxe 
triviale en un contenu proprement formate. 


Mettre en place un editeur visuel 

La zone d edition de Drupal peut sembler bien pauvre pour un contributeur 
qui na aucune envie d’apprendre une syntaxe XHTML ou meme 
Markdown. Ce genre de contributeur - generalement non technique - pre- 
fererait une edition plus intuitive comme le permet un traitement de texte. 
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II n’y a rien en standard dans Drupal pour permettre la mise en place 
dun tel editeur, mais comme toujours, les modules contributions sont la 
pour le completer, et dans ce cas, il s’agit du module Wysiwyg API 
(WYSIWYG pour What You See Is What You Get , qui est l’expression 
consacree pour les editeurs visuels). 

Ce module n est pas un editeur visuel en soi, mais bien mieux que cela, 
c’est un systeme permettant d utiliser l’editeur visuel de votre choix. II 
existe en effet de nombreux projets libres d’editeurs fondes sur Java- 
Script, chacun ayant ses inconvenients et ses avantages. Pour notre 
exemple, nous allons utiliser TinyMCE, lun des plus connus. 

Pour commencer, vous devez telecharger, installer et activer le module 
Wysiwyg API. Ceci etant fait, nous commen^ons par faire un tour dans 
son parametrage en allant dans Configuration du site > Wysiwyg. 

Laissons pour l’instant le debut du formulaire et interessons-nous plutot 
a la section Installation Instructions (eh oui, encore un module non traduit 
en fra^ais). 


URL Module Wysiwyg API 

► http ://d r u pa I . o rg/p roj ect/wys i wyg 


openWYSIWYG (Download) Not installed. 

Extract the archive and copy its contents into a new folder in the following location: 
sites/all/libra ries/openwysiwyg 

So the actual library can be found at: 

sites/all/libraries/openwysiwyg/scripts/wysiwyg . js 

TinyMCE (Download) Not installed. 

Extract the archive and copy its contents into a new folder in the following location: 
sites/all/libra ries/tinymce 

So the actual library can be found at: 

sites/all/libra ries/tinymce/jscripts/tinyjnce/tinyjnce . js 

marldtUp (Download) Not installed. 

Extract the archive and copy its contents into a new folder in the following location: 
sites/all/libra ries/markitup 

So the actual library can be found at: 

sites/all/libraries/markitup/markitup/j query . markitup . js 

NicEdK (Download) Not installed. 

E«tractthe archive and copy its contents into a new folder in the following location 
sites/all/libra ries/nicedit 

So the actual library can be found at: 
sites/all/libra ries/nicedit/nicEdit . js 


Figure 7-61 

Choix de la bibliotheque JavaScript 
d'edition visuelle 
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Figure 7-62 

Telechargement de I'archive de TinyMCE 


Figure 7-63 

Telechargement du pack de langue frangaise 


Figure 7-64 

La bibliotheque TinyMCE 
est maintenant operationnelle 
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Vous avez ici un aper^u de tous les editeurs visuels que ce module prend 
en charge. Autant dire la tres grande majorite. II vous est a chaque fois 
donne le nom du projet, un lien download pour telecharger l’editeur, et 
l’endroit oil vous devez l’extraire. En effet, ce module ne contient aucun 
editeur par defaut. 

Pour notre exemple, nous allons installer l’editeur TinyMCE. Pour cela, 
cliquez sur le lien download et telechargez I’archive j Query package (une 
version optimisee pour j Query, qui est installe en standard avec Drupal). 


jQuery package This package contains special jQuery build of TinyMCE and ajQuery 

integration plugin. 

tinymce_3_2_5 Jquery .zip 


Revenez ensuite sur la page d’accueil de TinyMCE, puis cliquez sur le 
lien Language pack services. Nous allons telecharger la traduction fran- 
chise pour l’interface de l’editeur, en cochant pour cela la ligne French et 
en cliquant en has de page sur le bouton download. 

I Hi [XML] French 23.5 Complete 2009-06-07 


Creez, comme indique dans l’aide du module Wysiwyg, un dossier 
sites/all /libraries et decompressez la premiere archive dans ce dos- 
sier de maniere a former un sous-dossier ti nymce. Lorsque vous avez ter- 
ming, le chemin si tes/al 1/1 i brari es/ti nymce/ j sc ri pts/ti ny_mce/ 
tiny_mce.js doit donner acces a un fichier valide. Ensuite, decom- 
pressez le contenu de I’archive de langue dans le dossier sites/all/ 
1 i brari es/ti nymce//jscri pt/ti ny_mce. 

Ceci fait, retournez sur la page de configuration du module Wysiwyg 
API, et pressez F 5 (ce qui reactualise la page). TinyMCE est a present 
installe et pret a etre utilise. 

if TinyMCE (Download) 3.2,5 


Avant de poursuivre, il va nous falloir bien comprendre ce que fait exac- 
tement le couple Wysiwyg API-TinyMCE. 

TinyMCE est un script JavaScript, il s’execute done sur le navigateur. Son 
role est de permettre une edition visuelle (mise en gras, titres, etc.) et de 
fournir au moment de l’enregistrement un contenu formate en XHTML. 
Drupal re^oit ce code XHTML et le stocke dans la base de donnees. 
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Lorsque le contenu devra etre affiche, Drupal ressortira de la base de 
donnees le contenu XHTML precedemment envoye par TinyMCE, et 
le fera passer dans le format d’entree selectionne pour ce contenu. Ce 
format d’entree fournira ainsi un contenu XHTML eventuellement 
modifie, qui sera ensuite affiche dans le navigateur web. 

De ce type de fonctionnement, nous pouvons deduire deux faits impor- 
tants. 

• TinyMCE est une sorte de super zone d’edition qui nous evite de 
taper du code XHTML. Pour Drupal, il n’y a done aucune difference 
entre un code XHTML tape a la main dans la zone d’edition stan- 
dard et du code XHTML fabrique par TinyMCE. 

• Comme TinyMCE ne fabrique que du code XHTML, le format 
d’entree utilise doit etre capable de comprendre le XHTML. Ce 
pourra done etre le format Full HTML, ou encore Filtered HTML, 
mais en aucun cas Markdown. 

C’est pour cela que le module Wysiwyg API n’ active pas directement 
TinyMCE, mais vous propose via son parametrage d’associer TinyMCE 
au format d’entree de votre choix. A vous d’en choisir un qui soit com- 
patible avec le code genere par cet editeur, en l’occurrence Filtered 
HTML ou Full HTML. 

Pour creer l’association, retournons voir le haut de la page de parame- 
trage de Wysiwyg API que nous avons laisse tout a l’heure de cote. C’est 
ici qu’il est possible de selectionner un editeur pour un format donne. 
Selectionnez done TinyMCE pour le format Full HTML. 


Attention Toute le monde n'aime pas les 
editeurs visuels 

Le risque que vous encourrez a associer I'editeur 
visuel au format d'entree Full HTML est celui 
d'enerver vos contributeurs aimant saisir leur 
code a la main, et ce meme s'il est possible de le 
desactiver a la volee. Dans ce cas, utilisez 
I'option Autoriser les utilisateurs a choisir 
un editeur par defaut dans le Parametrage 
par base du module Wysiwyg. Ainsi les utilisa- 
teurs pourront, depuis leur compte, decider si 
oui ou non, il desirent utiliser I'editeur visuel. 


Full HTML 


TinyMCE 3.2.5 


Figure 7-65 

Selection d'un format d'entree a associer a I'editeur visuel 


Vous avez vu apparaitre deux liens, l’un permettant de modifier le para- 
metrage de I’editeur, l’autre de casser l’association entre le format 
d’entree et I’editeur. Cliquez sur le lien Modifier. Dans le formulaire qui 
apparait, vous pourrez regler tous les details de I’editeur (boutons affi- 
ches, apparence, etc). 

Dans la premiere section, Basic setup, commen^ons par choisir la langue 
fra^aise (fr). 


Langue : 



The language to uae for the editor interface. Language codes are based on the ISO-639-2 
format. 


Figure 7-66 

Choix de la langue franchise pour TinyMCE 
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Figure 7-67 

L'editeur visuel en action lors 
de I'edition d'un contenu 


Ensuite dans la section Cleanup and output , activons les options : 

• Verify HTML, qui bloquera les tentatives d’ecriture de code dangereux ; 

• Convert <font> tags to styles, pour produire une mini-feuille de style et 
par consequent un meilleur code XHTML ; 

• Remove linebreaks, pour enlever les retours chariot inutiles ; 

• Apply source formating, qui permettra de produire un code XHTML 
propre et lisible ; 

• Force cleanup on standards paste, pour epurer le code XHTML des 
« saletes » introduites lors d un copier-coller a partir de Microsoft 
Word. 

Le parametrage est a present termine et vous pouvez l’enregistrer. Pour 
tester le nouvel editeur, redevenons Marine. Editons l’article de bien- 
venue et, dans les formats d’entree, selectionnons si ce n est pas deja fait 
Full HTML. TinyMCE devrait apparaitre automatiquement a la place de 
la zone d’edition standard de Drupal. 

0 Afficher le resume en mode pleine paqe 

Corps : J 



Des active r le teste riche 


Figure 7-68 

Application dune mise en forme 
par l'editeur visuel 


Comme vous le voyez, l’editeur a bien pris en compte notre ancien for- 
matage (« ses valeurs » en gras). Notez aussi le lien Desactiver le texte 
riche qui vous permet de basculer de l’editeur visuel a l’editeur standard, 
et vice versa. Vous pouvez maintenant tester l’editeur en appliquant 
quelques nouvelles mises en forme. 


Corps : 

~b] 1 U ABe : m m 

&£ & 0L j W HTmL ■ 


1 H j Styles ^ Paragraphs ^ ■ 

[Sj | x 1 1 n 


GLI Atticher le resume en mode pleine page 

\WW\* c“ i* 


Colchique CortseiL 


Bienvenue sur le sltej 

le cabinet de conseil en ressources humaines qui a Hethique au fond du coeur. 

Vous trouverez sur notre site une presentation complete, des ses intervenants etde ses valeurs. 
Vous pourrez aussi decouvrir nos publications ainsi que nos billets d’humeur. Bonne visite Llequipe 
httn cnlchinup-cnnRfii fr ' 

Chemin: p 

Desactiver le texte riche 
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Lorsque vous avez termine, enregistrez comme d’habitude pour juger du 
resultat. 


8 ju illst 3009 - 11:11am — Marine 
Bienvenue sur le site Colchique Conseil. 

le cabinet de conseil en ressources humaines qui a Hethique au fond du coeur. 

Vous trouverez sur notre site Line presentation complete, des ses intervenants etde ses valeurs. Vous 
pourrez aussi decouvrir nos publications ainsi que nos billets d'humeur. Bonne visite Llequipe 
http ://wwW .co Ic h iq ue-co n se i ,f r/ 


Figure 7-69 

Le resultat formate par I'editeur TinyMCE 


Le texte a bien pris en compte les nouveaux formats et le format d’entree 
continue de fonctionner en transformant les URL en liens. 

De la meme maniere, si vous voulez faire plaisir a vos visiteurs (ceci dit, 
tout le monde n’apprecie pas...), vous pouvez activer lediteur visuel pour 
les commentaires. Pour cela, nous allons associer cette fois TinyMCE au 
format Filtered HTML qui, rappelons-le, est le format par defaut pour 
tous les utilisateurs anonymes ou non, et sert done pour les commentaires. 
Appliquez a cette association le meme parametrage que precedemment. 

Deconnectez-vous ensuite pour juger du resultat en tant que visiteur 
anonyme. 


Repondre 


Votre nom : 

[Roberto 


Adresse electronlque : 


[roberto@miopalnnQ.com 


Le contenu de ce champ sera maintenu prive et ne sera pas affiche publiquement. Si vous avez un compte gravatar, 
I'utilisez pour afficher votre avatar. 


Page d aocuell : 

[http://rQberto.com | 

Commentalre : 

B I styles T Paragraphs T := |= | =W I I J 

# HTmL — <2 [S] I x* | n 

Sympa ce nouvel editeur de commentaires lll| 


Chemin: p ^ 

Disable rich-text 


Figure 7-70 

TinyMCE utilise dans les commentaires 
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Vous pouvez encore ameliorer le parametrage de cette association (sec- 
tion Buttons and plugins ) en activant uniquement les boutons utiles pour 
un commentaire. Ceci est d’autant plus judicieux que la majorite des for- 
matages proposes par defaut risquent d'etre filtres par HTML filter. 


Buttons and plugins; 


Figure 7-71 

Choix des boutons a afficher 
pour Tedition des commentaires 


0 Bold 

0 Italic 

0 Underline 

□ Strike-through 

□ Align left 

LH Align center 

1— 1 Align right 

O Justify 

— 1 Bullet list 


Vous obtiendrez alors une barre de menus davantage en accord avec les 
circonstances : 


Figure 7-72 

TinyMCE en mode allege 
pour les commentaires 


Commentaire : 

B / D ;E |E U (6* 

Sympa ce nouvel editeur de commentaires !!! 


Comme vous le voyez, le couple Wysiwyg API-TinyMCE fonctionne a 
merveille. Vous pouvez cependant consacrer un peu de temps a installer les 
autres editeurs pour determiner au final celui qui vous convient le mieux. 


Bon A SAVOIR Un editeur visuel, non visuel... 

Sachez a ce sujet que vous pouvez sans aucun probleme associer un editeur a un premier format 
et un autre editeur a un second format. Vous pouvez ainsi garder par exemple la puissance de 
TinyMCE pour les contenus, et choisir la legerete de MarkitUP pour les commentaires. 

MarkitUP est en effet un editeur visuel tres particulier, car il permet I'edition des balises et non 
pas des styles. II fonctionne a ce titre comme un editeur HTML. II peut aussi etre configure pour 
reconnaitre d'autres syntaxes comme phpBB (avec le filtre d'entree adequat, evidemment). 
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En resume 


• N’oubliez jamais que le type de contenu est un element parametrable. 
Lorsque vous vous demanderez ou se regie tel ou tel aspect lie au 
contenu - par exemple apres avoir installe un nouveau module ayez 
le reflexe d’aller voir si ce parametrage ne se trouve pas dans les types 
de contenu. 

• Les commentaires sont considered comme des contenus ; par conse- 
quent, leurs parametres sont regies par type de contenu et leur admi- 
nistration se trouve dans la section Gestion des contenus. 

• Les formats d’entree permettent la transformation de ce que vous 
avez saisi en un code XHTML. Vous pouvez creer de nouveaux for- 
mats ou etendre des formats existants a l’aide de filtres fournis par des 
modules. 

• Si vous avez besoin d’aide, n hesitez pas a poster des questions pre- 
cises dans la section Support general de drupalfr.org. 
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Creer des contenus avarices 


Nous savons a present gerer de bout en bout un simple article. 
Mais Drupal permet d’aller beaucoup plus loin dans la gestion 
des contenus, aussi etudierons-nous dans ce chapitre les 
methodes pour definir des types de contenu plus complexes 
permettant d’operer une separation propre entre Tinformation 
et sa presentation. Nous aborderons egalement les techniques 
de creation de listes de contenus, afin d’ameliorer leur 
visibility. 


SOMMAIRE 

► Hierarchiser les contenus 

► Gerer I'historique des contenus 

► Creer des contenus complexes 

► Regler finement les droits 
d'acces 

► Fabriquer des listes de contenus 
personnalisees 
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Utiliser les livres 

Dans notre storyboard, nous avons defini le besoin dune FAQ_(Fre- 
quently Asked Questions ou Foire aux questions). Pour repondre a ce 
besoin, nous utiliserons le module Book, qui fait partie de la distribution 
standard de Drupal, tout en etant desactive par defaut. 

Originellement con^u pour rediger la documentation de Drupal, le 
module Book permet de lier un ensemble de contenus les uns aux autres 
en une arborescence formant un livre. II permet ainsi d’assigner a 
n importe quel contenu, peu importe son type, une reference a un con- 
tenu parent, et ce, jusqu au contenu le plus eleve dans la hierarchie qui 
devient en quelque sorte la couverture du livre. 


Figure 8-1 

Le module Book permet de structurer les 
contenus en arborescences 



Meme si Book rend cette fonction accessible a tous les types de contenu 
existants, il ajoute cependant un nouveau type de contenu appele Book 
page (Page de livre) qui est le type que Ton utilisera naturellement pour 
construire un livre meme si une fois de plus, ceci n a rien d’obligatoire. 

II faut bien comprendre que cette notion de « livre » est avant tout une 
metaphore. Vous pouvez utiliser Book pour bien d’autres choses qu un 
livre. II peut s’agir d un dossier traitant d un sujet donne et regroupant 
un ensemble d’articles se rapportant a ce sujet, ou encore pour notre 
exemple, d une FACX 
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En effet, pour des raisons de lisibilite, l’ensemble des questions de notre 
FAQjie vont pas resider sur une seule et meme page. Nous allons creer 
une page FAQ qui en explique le role et qui donne acces a deux autres 
pages, une pour chaque grand domaine de competence de la societe. Et 
chaque page « domaine de competence » va a son tour permettre d’affi- 
cher les pages de competences specifiques contenant chacune une liste 
de questions. Nous pouvons done parfaitement utiliser le module Book 
pour ce genre d usage en utilisant comme hierarchie la structure des 
domaines de competence de la societe que nous avons definie dans le 
chapitre 3, « Bien definir son projet ». 


£ 




Ressources 

Humaines 


£ 


1 


Recrutement 


Bilans de 
competence 


Systemes et 
reseaux 


Systemes 
d 'information 




r 

r 

Assistance a 
mait rise 
d‘ouvrage 


1 


Ingenierie 

logiciel 


Figure 8-2 

Arborescence cible de notre FAQ 


Creation de la FAQ 

Nous allons commencer par creer une premiere page de livre qui sera en 
quelque sorte la couverture de notre FACX Pour cela, creez en tant 
qu’administrateur un nouveau conte nu de type Page de livre ( Book page ), 
et commencez, comme d’habitude, par saisir son titre. 


Creer 'Book page' 

Tltre : 

| FAQ | 

C> Parametres du menu 

Corps : 

B / M M. M M Styles ▼ Paragraphe - ;E jE | = iW- di 2L -J HTmL — s2 1 4^1 1 1 X 2 

x* | n 

Ceci est la FAQ de colchique conseil 

Chemin: p 

Disable rich-text 


Figure 8-3 

Creation d'un contenu 
de type Page de livre 
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Les sections qui suivent sont les memes que pour les autres types de con- 
tenu a l’exception de Structure du livre. Dans cette section, nous selec- 
tionnerons Creer un nouveau Uvre dans le champ Uvre. Ceci fait, nous 
pouvons enregistrer notre contenu en prenant soin de verifier que son 
statut Publie est active et l’option Promu en page d'accuei I desactivee. 

Ceci fait, nous obtenons la version complete du contenu qui differe 
quelque peu de ce que nous avons pu voir jusqu’ici. 


FAQ 


Modifier Structure 


Le contenu 'FAQ, de type 'Book page', aete cnee. 


ven, 06/1 2 ; 30C© - 08:48 — adrninistrateur 


Figure 8-4 

Depuis la page cTun livre peuvent 
etre creees les pages enfant. 


Ceci est la FAQde colchique conseil 


Ajo ute r u ne p age e nf ant Ajo ute r u n co m me ntai re 


Bon A SAVOIR Le module Book hierarchise 
tous les types de contenu 

Le module Book va plus loin que la fourniture d'un 
contenu de type Page de livre. II permet de hierar- 
chiser n'importe quel autre type de contenu. Si 
vous vous rendez dans Gestion du contenu > 
Books, puis dans I'onglet Parametres, vous avez 
la possibility de cocher les types de contenu que 
vous desirez hierarchiser en tant que livre, et en 
tant que page de livre. 


Structure du livre! 

Livre : 

| FAQ C | 

Vo lie page Tera une partie du livre ae lectio n ne . 

Element parent : 

| FAQ 0 I 

La page parents du Irvie. Le maximum de repays 
tant de paientee auqusl cas il y aura it un depasae 

Figure 8-5 

Creation d'un nouveau « livre » 


Comme vous le voyez, un nouveau lien Ajouter une page enfant vous 
permet ici de creer un nouveau contenu de type Page de livre, et qui aura 
pour parent notre page FACX Notez aussi la presence d un nouvel onglet 
Structure qui n est qu un acces rapide permettant de definir a quel livre ce 
contenu appartient et quel est son contenu parent. 

Creation des sections de FAQ 

Pour Theure, cliquez sur Ajouter une page enfant pour creer le chapitre 
« Ressources Humaines ». La procedure est la meme que pour n importe 
quel autre contenu : un titre « Ressources Humaines », et dans le corps, 
tout ce qui vous semble pertinent pour decrire ce chapitre. Dans la sec- 
tion Structure du livre , vous noterez que FAQ a ete automatiquement 
selectionnee en tant que page parent de notre contenu, de par Futilisa- 
tion du lien Ajouter une page enfant. Vous constaterez egalement Farrivee 
dun nouveau champ Livre qui a la meme valeur qu Element parent. En 
effet, lorsque nous avons choisi tout a Theure Toption Creer un nouveau 
livre , nous avons de facto cree un livre du meme nom que sa couverture. 

Pour que Faeces a notre FAQsoit plus simple, nous allons finir par la defi- 
nition d un alias sur le chemin du noeud, nomme simplement « faq ». Les 
questions seront alors accessibles par FURL http://www.colchique-conseil.fr/faq. 

Vous pouvez a present enregistrer ce premier contenu et poursuivre la crea- 
tion des autres chapitres (Systeme d' information ) et sections ( Recrutement , 
Systemes et reseaux , etc.). Dans chacun des corps (chapitres ou sections), 
nous allons pouvoir saisir des questions et des reponses : 
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[H ] 

Specrfie r op tionne lie merit une U R L alte mative parbquelle cette ressouioe peutetre accedee. Pareaemple, 
taper"abour quand vous ecrivez une page "a propos de". Utilise r un ehemin lelatrf et ne pas ajouterde 

slash final ou Talias d'URL ne fdnctionneia pas. Figure 8-6 

Definition d'un alias sur la couverture du FAQ 


Creer ‘Book page 1 

Titre : 

[Recrutement 

» Parametres du menu 


Corps : 

b i u j&z \w m m m \ styles 
x 1 | Q 

Qu'est-ce qti'tin recrutement ? 

Un recrutement est .... 


Figure 8-7 

Creation d'une page enfant 


Organisation des pages de livre 

Nous avons limite la hierarchie des contenus a trois niveaux, mais sachez 
qu’il n’y a sur ce point aucune limitation particuliere. 

Lorsque vous avez termine, allez dans Gestion du contenu > Litres. Nous 
retrouvons ici notre livre dans une liste. 

Livre Operations _ _ 

Figure 8-8 

modifier Herd re et les titnes |_g | jste deS livreS 


Cliquez maintenant sur modifier I'ordre et les titres. 


Tit re 

Operations 


4* [Ressources Humaines 

voir 

modifier 

supprimer 

4* [Bilans de competence 

voir 

modifier 

supprimer 

4*" [Recrutement 

voir 

modifier 

supprimer 

4* [ Syste me d 'i nfo rm atio n 

voir 

modifier 

supprimer 

4* [Systeme et neseaux 

voir 

modifier 

supprimer 

4* [Assistance a maitrise dtauvrage 

voir 

modifier 

supprimer 

4* [ingenieurie logiciel 

voir 

modifier 

supprimer 


Figure 8-9 

^organisation initiale 
de notre livre 
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Ergonomie Hierarchisation 

Nous avons deja utilise le systeme de Drupal per- 
mettant de reordonner dynamiquement les lignes 
d'un tableau. Lorsqu'il s'agit, comme pour le 
module Book, d'une hierarchie, il est aussi possible 
de la modifier en faisant glisser la ligne horizonta- 
lement. 


Nous constatons que, dans notre hate, nous avons commis pas mal 
d’erreurs dans la hierarchie, le tout emaille de quelques fautes de frappe. 
Ce n est pas grave, car nous pouvons tout modifier. Ce panneau nous 
permet en effet de reordonnancer nos pages et changer la hierarchie (en 
faisant glisser de gauche a droite et de haut en has) ainsi que renommer 
nos titres. Lorsque tout est rentre dans fordre, vous pouvez enregistrer. 


Figure 8-10 

Le meme, un peu mieux agence 


Titre 


♦F | Ressources Humaines 
*i* [flee ruts me ni 
*f* tlilansde competence 


[Systeme deformation 
■f* Sy ste ire et ne se aux 


rt* As sistance a maitrfse d 0 u vraepe 


*f* Ingenierie logiciel 


Operations 


voir 

modifier 

sup primer 

voir 

modifier 

sup primer 

voir 

modifier 

sup primer 

voir 

modifier 

sup primer 

voir 

modifier 

sup primer 

voir 

modifier 

sup primer 

voir 

modifier 

sup primer 


Notre FAQ^est maintenant correctement organisee. Pour y acceder, 
retournons sur la page de gestion des livres en cliquant sur Books sous le 
titre de la page, puis sur FAQ. 


FAQ 


Modifier Structure 


von . Oof 1 2/2009 - 08 : 49 — adm in istrateu r 


Geci est le FAQde colchique conseil 


Figure 8-11 

Presentation finale 
de la couverture du livre FAQ 


O Ressources Humaines 
i> Systeme d 'information 


Ressources Humaines > 


Comme vous le voyez, le module Book integre un systeme de navigation 
qui nous permet de circuler d un chapitre a fautre et d une page a fautre. 


Recrutement 


Modifier 


Structure 


van, 06/1 22009 - 09:00 — adm in strata nr 


Figure 8-12 

La navigation est possible 
dans plusieurs directions 


Qu'est-ce qu'un recrutement ? 

U n rec ruts me nt e st . . . . 

- Ressources Humaines haut Bilans de competence ■ 
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Nous verrons un peu plus loin dans cet ouvrage comment rendre cette 
navigation encore plus intuitive. 


Modules magiques 

Un module specialise pour les FAQ 


L'utilisation de Book pour decrire une FAQ est 
avant tout un pretexte pour nous permettre de 
comprendre le fonctionnement de ce module 
important. Pour une FAQ reelle, II existe un module 00 
specialement dedie a cet usage qui se nomme tout 
simplement Faq. 

► http://drupal.org/project/faq 

Comme nous l’avons vu dans sa description generale, Drupal permet 
d’archiver les versions successives d un contenu - appelees revisions - et 
vous permet ainsi de revenir en arriere si une modification ne vous con- 
vient plus. 

Lorsque nous avons parametre le type de contenu Article, nous avons 
indique que nous desirions archiver une revision pour chaque modifica- 
tion du contenu. Ayant maintenant fait un certain nombre de modifica- 
tions sur notre premier article, il est temps de voir ce que donnent ces 
fameuses revisions. 

Pour cela, redevenons Marine, et dirigeons-nous vers la version com- 
plete de r article, puis cliquons sur le lien Revisions. 


Gestion des revisions 

Consultation des revisions 


Versions anterieures de « Bienvenue » 

Voir Modifier 

Les revisions permettentde suivne les differences entre plusieurs versions d'une 
contribution. 

Revision 

0S/07/2009 - 1 3:42 par Marine 
Mise en forme avec Hediteur visuel 

08/07/2009 - 1 2:45 par Marine 
C h ange me nt d u fo rm at d le ntree 

00/07/2009-12:43 par Marine 
Transformation en article de bienvenue... 

08/07/2009 - 1 1 :55 par administrateur 
Ajoutd'un alias sur I'article 


Figure 8-13 

L'historique des revisions du contenu 


08/07/2009 -11:11 par Marine 
On a tous commence un jour I 


Operations 


version en cours 
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Figure 8-14 

Line revision supplemental 


Figure 8-15 

L'historique des revisions pour I'administrateur 


Nous decouvrons ici que nous avons nourri l’historique des revisions 
sans meme le savoir. Nous voyons aussi tout l’interet de systematique- 
ment saisir un message d’explication dans le journal. Nous savons ainsi 
parfaitement a quelle operation correspond chaque version. Pour 
l’exemple, nous allons modifier a nouveau ce contenu pour creer une 
nouvelle revision en mettant comme message dans le journal 
« Correction de quelques coquilles ». 


Revision 

Ope ratio re 


0 9/07/2 0 09 - 1 3:54 par Marine 

Correction de quelques coquilles 

version en cours 

03/07/2009 - 1 3:42 par Marine 

Mise en forme avec Hediteur visuel 



Administration des revisions 



Redevenons maintenant Administrateur pour voir 
sions sur cet article apparaissent pour ce role. 

comment 

Revision 

08/07/2009 - 1 3:54 par Marine 

Correction de quelques coquilles 

Operations 

version en cours 

08/07/2009 - 1 3:42 par Marine 

Mise en forme avec I'editeur visuel 

revenir 

supprimer 

08/07/2009 - 12:45 par Marine 

C h anqe me nt d u fo rm at d 'e ntree 

revenir 

supprimer 

08/07/2009 - 12:43 par Marine 

Transformation en article de bienvenue... 

revenir 

supprimer 

08/07/2009 - 1 1 :55 par administrateur 

Ajoutd'un alias sur 1 'article 

revenir 

supprimer 

08/07/2009 -11:11 par Marine 

On a tous commence un jour ! 

revenir 

supprimer 


Comme vous le voyez, l’ecran est le meme a ceci pres que l’administra- 
teur dispose de controles supplementaires. II peut supprimer une revi- 
sion, mais aussi, revenir sur une revision. Pour comprendre ce que cela 
implique, cliquons sur le lien revenir sur la version qui precede la derniere 
revision de Marine. 
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Revision 


Operations 


O 8/07/2 009 - 1 3:59 par administrateur 
Copier la version du 8 juiUet 2009 - 1:42pm. 

0S/07/2009 - 1 3:54 par Marine 
Correction de quelques coquilles 

08/07/2009 - 1 3:42 par Marine 
Mise en forme avec I'editeur visuel 


version en cours 


revenir supprimer 


revenir supprimer 


Figure 8-16 

L'administrateur peut revenir en arriere 
sur une revision donnee. 


Le systeme de revisions de Drupal est ainsi fait que le retour en arriere 
consiste en realite a recopier le contenu de cette revision et a lutiliser pour 
en creer une nouvelle. Nous sommes ainsi assures de ne jamais rien perdre. 

Nous pouvons cependant decider de supprimer une revision, par 
exemple favant-derniere en date. 


Revision 

08/07/2009 - 1 3:59 par administrateur 
Copier la version du 6 juiiiet 2009 - 1:42pm. 


Operations 


version en cours 


08/07/2009 - 1 3:42 par Marine 
Mise en forme avec I'editeur visuel 


Figure 8-17 

revenir supprimer **' 

Revision supprimee 


Ce systeme est en quelque sorte la memoire de vos contenus, doublee 
dune mini machine a remonter le temps. Ceci etant dit, ce confort a un 
prix et chaque revision prend chaque fois un peu plus d’espace de stoc- 
kage sur la base de donnees. A vous de determiner si cette securite est 
utile, sachant que la reponse est tres souvent oui. 


Modules MAGIQUES Afficher visuellement 
les differences entre revisions 

Le module contribution Diff est le compagnon 
ideal des revisions. II rajoute des options a la liste 
des revisions pour vous permettre d'afficher les 
differences entre deux revisions. 

► http://drupal.org/project/diff 


Classer les contenus 

Qu’est-ce que la taxonomie ? 

Comme nous l’avons deja vu dans les premiers chapitres, pour remonter 
a l’origine du terme, la taxonomie est la science de la classification. Son 
objectif est de regrouper ce qu elle cherche a classer en ensembles appele 
« taxons ». Ces taxons sont eux-memes regroupes en taxons parent 
jusqu a former une taxonomie. 
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Pour prendre un exemple, une taxonomie des animaux ressemblerait, de 
maniere aussi simplifiee qu incomplete, a ceci : 


o> 

£ 


£ 





Vertebres 


Irwertebres 



Figure 8-18 

Une taxonomie appliquee aux animaux 



A quoi sert la taxonomie ? 

Une taxonomie va tout simplement nous permettre d’assigner des taxons 
a chacun de nos contenus de maniere a pouvoir les retrouver plus facile- 
ment. En langage plus clair, cela va nous servir a determiner des catego- 
ries oil ranger nos contenus. 

La taxonomie et Drupal 

Drupal vous permet de creer des classifications refletant vos besoins spe- 
cifiques pour ensuite y rattacher des contenus. Si nous reprenons 
fexemple ci-dessus, un article traitant des grenouilles serait rattache au 
taxon Amphibien. II serait alors possible, et c’est la tout l’interet, de 
rechercher tous les contenus qui parlent d’amphibiens, mais aussi de ver- 
tebres, et a chaque fois d’obtenir une liste de contenus associe a ce sujet. 

De la maniere la plus generale possible, le systeme de classification de 
Drupal se definit selon les regies suivantes. 

• Un terme (qui serait fequivalent du taxon ), est un mot (ex. « reptile ») 
auquel il est possible d’associer une description et eventuellement une 
serie de synonymes et de termes connexes. 
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• Un vocabulaire (qui serait l’equivalent de la taxonomie ) est un 
ensemble de termes. Cet ensemble dispose d un nom (ex. « Les 
animaux ») et est complete la aussi par une description. 

• Un terme appartient a un et un seul vocabulaire. 

• Un terme peut etre relie a un ou plusieurs autres termes au sein d’un 
meme vocabulaire. 

• Un conte nu peut etre relie a un ou plusieurs termes provenant dun 
ou plusieurs vocabulaires. 

Lutilisation de taxonomie pour definir ce mode de classement risque de cho- 
quer les plus rigoureux. En effet, en appliquant ces regies, nous sommes ici 
dans une vision plus large qu’une simple taxonomie, car nous pouvons 
definir des relations terme parent-terme enfant sans ordre particulier et sur- 
tout sans hierarchie particuliere. Cependant, dans la grande majorite des cas, 
ce seront bien des hierarchies de termes que nous definirons ici. 


Bon A SAVOIR La taxonomie et les graphes 

Le systeme de classement de Drupal se rapproche plus de la notion 
mathematique de graphes (http://fr.wikipedia.org/wiki/Theorie_des_graphes). II 
est ainsi possible de definir plusieurs parents pour un meme terme, et 
ce, sans orientation particuliere. 

La notion multiparent en elle-meme peut presenter certains avantages 
comme celui de permettre la fusion de plusieurs vocabulaires. En effet, 
si nous avons un vocabulaire « les plantes » et un autre « recette de 
cuisines », nous aurions deux termes « basilic », I'un en tant que plante, 
I'autre en tant qu'ingredient. Plutot que rattacher deux termes 
« basilic » a un contenu, nous pouvons preferer creer un super-vocabu- 
laire avec deux branches « plantes » et « recettes ». Le terme « basilic » 
pourra done etre relie a ces deux parents. Ainsi en cherchant « basilic », 
vous aurez a la fois les articles se rapportant a la plante, et ceux qui I'uti- 
lisent en tant qu'ingredient. 

Ceci etant dit, des lors que vous liez un terme a deux parents, Drupal bas- 
cule le vocabulaire dans un mode particulier qui vous interdira, et e'est 
bien logique, de reorganiser les termes entre eux de maniere graphique. 


Ajouter un nouveau vocabulaire 

Maintenant que nous voyons mieux comment fonctionne le systeme de 
classement, nous allons fexploiter pour decrire la hierarchie de nos 
domaines de competence telle que decrite dans le chapitre « Bien definir 
votre projet » (comme pour la FAQ). 
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Figure 8-19 

La taxonomie des domaines de 
competence de Colchique conseil 



Tout commence par l’ajout du vocabulaire que nous allons appeler logi- 
quement « Domaines de competence ». Notez que vous n etes en rien 
limite, tant en nombre de vocabulaires que de niveaux de termes quun 
vocabulaire va pouvoir contenir. 

Pour aj outer un vocabulaire, il nous faut redevenir Administrateur et 
nous diriger vers Administration > Gestion du contenu > Taxonomie. Nous 
avons sur cette page une liste pour l’instant vide que nous allons com- 
pleter de ce pas en cliquant sur le lien Ajouter un vocabulaire. 

Une fois le nom donne, vous pouvez aussi rediger une description et un 
court texte d’aide qui vous seront utiles si vous etes amene a gerer de 
nombreux vocabulaires. 


Figure 8-20 

Creation d'un nouveau vocabulaire 


Nom du vocabuhire : * 

[Domaines de Competence 

Le nom de ce vocabulaire. i.e. 'Etiquettes 

Description : 

Les domaines de competence de Colchique 


Desorption du vocabulaire ; peutetre utilise pard'autres modules. 


Figure 8-21 

Association du vocabulaire 
a des types de contenu 


^7 Types de contenu 

Types de contenu ; 

IZI Article 
Page 

SS lectio n ne r les types de contenus a c lass if ie r g race a ce vocabulaire. 
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Drupal permet dans la section suivante de definir les types de contenu pour 
lesquels ce vocabulaire pourra etre utilise. Nous allons selectionner Article. 


Parametnes 


□ Etiquettes 

Lea te rmes so nt cress par les utilisateuiB lots de la creation de contenus en saisE^nt une liste de mots 
separes pardes virgules. 

□ Choix multiple 

Permet d'affecte r aux contenus plus d'un tenne de ce vocabulaire (to u jo u rs viai pour les etiquettes). 

^ Obligatoire 

Au mo ins un tenne de ce vocabulaiie doit^tre se lectio nne lorsde la p ub licatio n d'un contenu. 


Figure 8-22 

Mode de fonctionnement du vocabulaire de contenu 


Poids : 



Les vocab u laires so nt affiches parordre crois^nt de poids. 


I 

00 


La section suivante decrit le mode de fonctionnement du vocabulaire. 

Tout d’abord, il permet de fixer son caractere Obligatoire. Si cette case est 
cochee, un contenu utilisant ce vocabulaire ne pourra pas etre valide tant 
qu au moins un terme n aura pas ete selectionne. 

Loption Choix multiple permet au redacteur du contenu de selectionner 
plusieurs termes de ce vocabulaire pour un meme noeud. 

Loption Etiquettes est un mode particulier du fonctionnement que nous 
venons de decrire. En effet, dans le mode standard, il est necessaire que 
les termes soient saisis avant qu un contributeur puisse les rattacher a son 
contenu. Lorsque vous selectionnez l’option Etiquettes , le contributeur 
pourra lui-meme donner la liste des termes qui se rapportent a son con- 
tenu. Cette option permet de se liberer de la creation prealable d une 
arborescence de termes, mais presente deux inconvenients : 

• les termes que saisira le contributeur ne pourront etre rattaches qu a la 
racine, pas question de creer des arborescences complexes de termes ; 

• une faute de frappe comme « Resource humaines » au lieu de 
« Ressources Humaines » ne sera pas detectee par Drupal ; il consi- 
derera que les deux entrees sont differentes et creera les deux termes. 

Le mode Etiquettes demande done a fadministrateur de verifier regulie- 
rement la liste des termes crees pour eventuellement les corriger, voire 
les reorganiser. 

Pour notre exemple, nous allons choisir les modes Obligatoire et Choix 
multiple. Une derniere option a ete passee sous silence : le Poids du voca- 
bulaire. En effet, lorsque plusieurs vocabulaires sont actives pour un 
meme type de noeud, cette option permet de determiner leur ordre 
d’affichage. Cette option est importante d un point de vue ergonomique, 
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mais, comme pour les attachements ou l’ordre des filtres d’entree, la liste 
des vocabulaires permet d’operer ce meme reordonnancement de 
maniere plus visuelle et done plus simple. 

Nous n’avons maintenant plus qua cliquer sur Enregistrer pour que le 
nouveau vocabulaire soit effectivement cree. 

Ajouter des termes 

Une fois le vocabulaire cree, vous etes renvoye a la liste des vocabulaires. 
II est maintenant temps d’y ajouter des termes. Pour cela, cliquez dans la 
liste sur le lien Ajouter des termes. Nous arrivons alors sur un formulaire 
assez simple compose en premier lieu du Nom du terme et de sa Descrip - 
tion. Saisissez Ressources Humai nes, puis la description de votre choix et 
enfin, cliquez sur Enregistrer. 


Ajouter un terme a ' Domain es de Competences' 

Liste 


Identification 


Figure 8-23 

Ajout du terme « Ressources Humaines » 


Mom du terme : 

(Ressources Humai nesj 
Nam de ce term& 


Le formulaire s’affiche a nouveau avec un message vous indiquant que 
votre terme a bien ete cree. Recommen^ons, mais cette fois-ci, avec le 
terme « Systemes d ’information ». 

Une fois le terme ajoute, nous sommes a nouveau pret a saisir un troi- 
sieme terme. II s’agira de « Recrutement » qu’il conviendra de relier au 
terme « Ressources Humaines ». Pour ce faire, saisissez d’abord le nom 
du terme Recrutement, puis deployez la section Options avancees. 


Options avancees 


Figure 8-24 

Association d'un terme enfant 
a un terme parent 


Parents : 


<cracine> 


Ressources Humaines 


Systemes d ’information 



Termee parents. 


Dans ce panneau, vous avez la possibility de selectionner le terme Parents 
de notre nouveau terme. Selectionnez Ressources Humaines. Vous cons- 
tatez qu’il est aussi possible de definir des termes connexes ( Notion asso - 
dee) represents par des termes existants, ainsi qu’une liste libre de 
synonymes (un synonyme par ligne pouvant etre une phrase). 
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Vous avez aussi la possibility de definir un poids permettant de changer 
l’ordre d’affichage des termes, mais il sera plus simple de faire cela un 
peu plus tard. En effet, comme pour la structure d un livre, Drupal dis- 
pose d un editeur visuel de termes qui nous permettra non seulement de 
changer l’ordre, mais aussi de deplacer les termes d un parent a l’autre. 
Pour mieux illustrer cette fonctionnalite, saisissez maintenant tous les 
termes encore manquants, mais cette fois sans definir le parent : saisissez 
juste les nom et description et enregistrez. 

Lorsque vous avez termine, vous pouvez juger du resultat en cliquant sur 
longlet Liste. 


Nom 

Operations 

* 

Assistance a maTtrise dduvrage 

editer 


Bilans de competence 

editer 

* 

Ingenierie logiciel 

editer 

* 

Ressources Humaines 

editer 


Recrutement 

editer 

* 

Systemes d'i information 

editer 

* 

Systemes et reseaux 

editer 


Figure 8-25 

Notre vocabulaire encore peu organise 


Cette page est Y editeur visuel dont nous parlions plus haut. Vous pouvez 
ici modifier chacun des termes (lien editer ) mais surtout organiser la 
position d’un terme en le faisant glisser de haut en has, et en le deplafant 
pour le rattacher a un parent different (ne pas oublier d’enregistrer une 
fois le deplacement effectue). Lorsque cette reorganisation est terminee, 
nous disposons d une taxonomie fonctionnelle : 


Nom 

Ope ratio re 

tf* Ressources Humaines 

editer 

Bilans de competence 4 

editer 

Recrutement 

editer 

4|* Systemes d'i information 

editer 

Systemes et reseaux 4 

editer 

*3+ Assistance a maTtrise dtauvrage * 

editer 

Ingenierie logiciel 4 

editer 


Figure 8-26 

Le meme vocabulaire avec tous les termes 
correctement hierarchises 


Assoder des contenus a des termes 

Nous avons associe notre vocabulaire au type de contenu Article, il nous 
est done possible maintenant d’associer un terme a n importe lequel des 
articles que nous allons creer ou que nous avons deja crees. Pour 
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l’exemple, le plus simple est de creer un nouvel article qui traitera de 
recrutement dans le domaine de l’ingenierie logiciel. 

Une fois sur la page de creation de l’article, vous pouvez saisir le titre, par 
exemple « Etat du marche de l’emploi pour les ingenieurs 
informaticiens ». Juste en dessous du titre, vous decouvrez un nouveau 
champ Domaines de competence. II s’agit de notre taxonomie qui a ete 
automatiquement associee aux conte nus de type Article. Nous avons 
cree un vocabulaire a choix multiple et obligatoire, nous avons done la un 
zone dans laquelle nous devons selectionner au moins un terme. Pour 
choisir plusieurs termes, maintenez la touche Ctrl enfoncee lorsque vous 
cliquez sur les termes. 


Figure 8-27 

Association du contenu aux termes 
Recrutement et Ingenierie logiciel 


Titre : 

|Etatdu marche de Hemploi pour les ingenieurs informaticiens 


Domaines de Competences : 


Ressources Humaines 
-Bilans de competence 


-Recrutement 


Systemes d 'information 


-Systemes et reseaux 


-Assistance a maitrise d'ouvrage 


-Ingenierie logiciel 

n 


Vous pouvez maintenant saisir le corps de votre article puis enregistrer. 
L’administrateur n a plus qua publier votre article. 

Renouvelez l’operation avec un second contenu relie cette fois aux 
termes Recrutement et Systemes et reseaux que nous ferons la aussi publier 
par Tadministrateur. 


Figure 8-28 

Association du contenu aux termes 
Recrutement et Systemes et reseaux 


Titre : 

jEtatdu marche de Hemploi pour les ingenieurs reseaux 


Domaines de Competences : 



Recherches par terme 

De nos deux contenus publies, observons le premier. 

Comme vous le voyez, en bas a droite, nous avons maintenant deux liens 
refletant les deux termes que nous avons associes a cet article. Cliquez 
maintenant sur le lien Recrutement. 


174 


www.frenchpdf.com 


Etat du marche de I'emploi pour les ingenieurs informaticiens 

dim. 0&1 4/3009- 10:23— Marine 

La arise touche t-elle les informaticiens ? 

Ajo Liter un commentaire 

Recrutement 

Ingenierie logiciel 

Figure 8-29 Apparition des termes dans la version resumee des contenus 


Recrutement 

Etat du marche de I'emploi pour les Administrateurs reseaux 

dim, O&'l 4/2009 - 10:30 — Marine 

Les administrateurs reseaux connaissentt-ils lacrise ? 

Ajo Liter un commentaire 

R ec rute me nt Syste me s et re se aux 

Etat du marche de I'emploi pour les ingenieurs informaticiens 

dim, O&'l 4/2009 - 10:23 — Marine 

Lacrise touche t-elle les informaticiens ? 

Ajo Liter un commentaire 

Recrutement 

Ingenierie logiciel 


Figure 8-30 Resultat de la recherche des contenus rattaches au terme Recrutement 


Drupal affiche alors une page de recherche contenant la liste de tous les 
articles lies au terme Recrutement. Nous pouvons de meme cliquer sur 
Ingenierie logiciel pour ne voir apparaitre cette fois qu’un seul contenu qui 
est le seul lie a ce terme. 

Le visiteur peut ainsi, de proche en proche, naviguer facilement a travers 
les termes de notre taxonomie et afficher la liste des contenus qui trai- 
tent de tel ou tel sujet. 

Pour aller plus loin dans ce que permet Drupal dans la recherche de 
termes, redevenez Administrateur et retour nez sur la liste des vocabu- 
laires. Ceci fait, cliquez sur le lien lister les termes du vocabulaire 
Domaines de competence. 

Vous etes alors face a une liste connue representant notre vocabulaire. 

Vous pouvez ici constater que chaque terme est un lien. Ainsi, si vous 
cliquez sur Recrutement , vous allez retrouver la meme page de resultat 
que precedemment. 

Revenez a la liste, et cette fois cliquez sur Ressources Humaines , vous 
obtenez alors une liste vide. 
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Figure 8-31 

Recherche infructueuse sur les contenus 
rattaches au terme Ressources Humaines 


Ressources Humaines 

II n'y a actue lie merit aucune contribution dans cette categorie. 


Ce comportement est pour le moins irritant : si Ton s’est donne la peine 
de hierarchiser les termes, c’est justement pour pouvoir elargir les 
recherches de la sorte. 

Mais avant de s ’inquieter, nous allons dissequer fadresse (URL) qui 
mene a cette recherche infructueuse, http://www.colchique-conseil.fr/taxonomy/ 
term/1 . Cette adresse doit etre lue comme « voici la liste de f ensemble des 
noeuds dont le terme de taxonomie a pour identifiant 1 ». En effet, 
chaque terme a un identifiant unique, quel que soit le vocabulaire auquel 
il appartient. Pour vous, fidentifiant peut etre different, il s’agit done 
d’adapter les exemples qui suivent en consequence. Notez seulement que 
vous pouvez toujours le retrouver en retournant dans la liste des termes, 
et en cliquant sur le terme dont vous cherchez fidentifiant. Le dernier 
chiffre affiche dans fURL est fidentifiant de votre terme. 

Vous allez maintenant modifier fURL dans la barre d’adresse de votre 
navigateur pour ajouter /2 a la fin et obtenir ainsi, http://www.colchique- 
conseil.fr/taxonomy/term/1/2, puis validez. Cette fois la liste des resultats est 
plus interessante : 


Ressources Humaines 


Etat du marche de I'emploi pour les Administrateurs reseaux 

dim. 06/1 4/2009- 10:30— Marine 


Les administrateurs reseaux connaissentt-ils lacrise ? 


Ajouter un commentaire 

Recrutement Systemes et reseaux 

Etat du marche de I'emploi pour les ingenieurs informaticiens 

dim, 06/1 4/2009 - 10:23 — Marine 


Lacrise touche t-elle les informaticiens ? 


Ajo Liter un commentaire 

Recrutement Ingenierie logiciel 


Figure 8-32 Recherche de profondeur 2 sur les contenus rattaches au terme Ressources Humaines 


La premiere recherche n a d’abord rien donne, car pour des raisons de 
performances, Drupal limite par defaut ses recherche a seulement un 
niveau, e’est-a-dire sur le terme lui-meme. En ajoutant /2, vous avez 
augmente la profondeur de la recherche a deux niveaux, englobant ainsi 
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les contenus rattaches a Ressources Humaines, mais aussi ceux rattaches 
aux termes enfant de Ressources Humaines, dont Recrutement. 

De la meme maniere, des lors que vous connaissez les identifiants de vos 
termes, il est possible de composer des URL de recherche complexes 
comme : 

• http://monsite.fr/taxonomy/term/A,B,C recherchera les contenus rattaches aux 
termes ayant pour identifiants respectifs A, B et C. Vous pouvez 
rajouter autant d’identifiants que necessaire a votre recherche prove- 
nant d un ou plusieurs vocabulaires. Vous pouvez rajouter a la fin un /N, 
oil N represente la profondeur de recherche desire ; 

• http://monsite.fr/taxonomy/term/A+B+C a le meme role que la syntaxe prece- 
dente, mais cette fois ne recherche que la presence d’au moins lun 
des termes. La aussi il est possible d’ajouter une profondeur. 


Modules MAGIQUES Naviguer dans la taxonomie 

Cette maniere de construire des URL pour faire une recherche peut sem- 
bler un peu barbare et en tout cas peu intuitive. Mais I'objectif de cette 
fonctionnalite est de fournir a la personne qui va realiser le site, les 
moyens de creer des liens hypertextes adaptes aux besoins ergonomi- 
ques. Cela pourra par exemple etre une serie de rubriques avec des 
termes associes aux documents de chacune d'elles. 

II vous est cependant possible d'ajouter une maniere simple de naviguer 
dans les vocabulaires sans passer par les URL, en utilisant le module 
Taxonomy navigator. Ce module fournit un bloc que nous apprendrons 
a mettre en place au chapitre suivant. 

Domaines de 
Competences 

Ressources Humaines 
Systemes d 'information 

Figure 8-33 Bloc du module Taxonomy navigator 

Dans le meme esprit, vous pourrez aussi utiliser la taxonomie pour 
generer des nuages d'etiquettes. Pour cela, vous pouvez utiliser le 
module Tagadelic. 

Ingenierie logiciel 

Recrutement Systemes 

et rise aux 

Figure 8-34 Nuage d'etiquettes grace au module Tagadelic 

Ces deux modules fournissent ce que I'on appelle des « blocs », une notion 
que nous aborderons dans le chapitre suivant, « Structurer les pages ». 
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Ajouter de nouveaux types de contenu 

Avant de voir pourquoi il peut etre interessant d’ajouter de nouveaux 
types de contenu, revenons sur nos definitions. 

Un type de contenu regroupe un ensemble de champs qui permettent de 
caracteriser les contenus appartenant a ce type. 

Dans de nombreux cas, les deux types de contenus fournis en standard 
par Drupal sont loin d'etre suffisants pour tous les usages. La necessite 
dun nouveau type de contenu peut en effet apparaitre si : 

• vous avez besoin d un type de contenu ayant un nom particulier (ex. 
billet, nouvelles, depeche, etc.) avec en outre des reglages specifiques 
(commentaires, publication, etc.) ; 

• vous avez besoin dun type de contenu dote de champs supplemen- 
taires non proposes en standard. 

Ajout de types simples 

Cette premiere possibility offerte par Drupal vous permet de creer tres 
facilement de nouveaux types de contenu qui seront totalement parame- 
trables, mais fajout de nouveaux champs sera impossible. Cette 
approche correspond done bien au premier cas de figure ou Ton cherche 
un nom de contenu different avec un parametrage specifique. 

C’est par exemple le cas du type de contenu Billet que nous avons 
evoque dans le chapitre « Bien definir son projet » : rien ne le distingue 
reellement d un Article, mis a part un usage different. 


Figure 8-35 

La definition du type Billet 



Billet 


Tit re 


Auteur 


Date de creation 


Domaines de 

* 

competence 

Corps 


Pour creer ce nouveau type, prenez le role Administrates, puis dirigez- 
vous vers Administrer > Gestion de contenu > Types de contenu , puis cliquez 
sur l’onglet Ajouter. 

Vous retrouvez alors un formulaire connu de configuration de contenu a 
la difference pres que les champs Nom, Type et Description sont ici 
vierges. Nous allons done saisir les informations suivantes : 
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Identification 


Nom : ‘ 

[Billet | 

Le nom affiche de ce type de contenu. Ce teste sera affiche dans la liste sur la page creer un contenu. Ce nom doit com me nee r 
parune lettra majuscule et ne do it co nte n ir q ue des letties, ch iff res. et G spaces. Ce nom dortetra unique. 

Type : * 

[billet ] 

Le nom interne de ce type de contenu. Ce teste seia utilise pourcontmire TURLde la page creer un contenu po u r ce type de 
contenu. Ce nom ne do it co nte n ir q ue des letties minuscules, deschiffres, et des caracteres de soulignement. Les caiacteres de 
so u lig ne me nt se ro nt co nve itis e n train d' union bra de la contraction des URL de la page Creer un contenu. Ce nom doit etre 
unique. 

Description : 

Utilisez ce type de contenu pourecrire un billet, clest a dire un contenu d'une page maximum pouvantetre 
lu en moins de 1 5 minutes. Si votre contenu est plus long que cela, il s'agirad'utiliser le type de contenu 
"Article" 


Une brave deserptbn de ce type de contenu. Ce teste sera affiche dans la liste qui se trouve sur la page creer un contenu. 


Figure 8-36 

Informations (^'identification 
du type de contenu Billet 


i 

00 


Dans la section Procedure de publication , nous allons cocher les elements 
suivants de sorte que, comme pour le type de contenu Article, une revi- 
sion soit creee automatiquement. En revanche, un Billet ayant moins 
d’importance qu un Article, nous allons autoriser la publication imme- 
diate en laissant actives les champs Publie et Promu en page d'accueil. 


Options pardefaut : 

0 Publie 

® Promu en page d'accueil 
U Epingle en haut des listes Figure 8-37 

|0| creer une revision Definition des options de publication par defaut 


Sur le reste des options, nous adopterons pour ce type de contenu un 
parametrage identique a celui de 1’ Article, notamment pour la gestion 
des commentaires. Une fois ces reglages termines, il ne reste plus qu a 
enregistrer le nouveau contenu. 

Pour que ce dernier devienne actif pour le role Contributeur, il est neces- 
saire d’aller dans la gestion des droits d’acces pour activer les permissions 
concernant ce nouveau type de contenu : 

• Create billet content (notez que certains termes de l’interface ne sont 
pas traduits, nous aborderons ce point un peu plus loin) ; 

• Edit own billet content ; 

• Delete billet content. 


179 


www.frenchpdf.com 


Creer des contenus 


Drupal 6 - Concevoir et deployer ses applications 


£ 


Figure 8-38 

Association du vocabulaire Domaines de 
competence au type de contenu Billet 


Figure 8-39 

Acces a la creation d'un type de contenu Billet 
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Enfin, il nous reste a ajouter le vocabulaire Domaines de competence a 
ce type de contenu. Pour ce faire, rendez-vous sur radministration de la 
taxonomie, modifiez le vocabulaire Domaines de competence, et cochez 
le type de contenu que nous venons de creer. 


Types de contenu 


Types de contenu : 
fZI Article 
0 Billet 
Page 


Notre type de contenu Billet est a present disponible pour les contribu- 
teurs. Vous pouvez le verifier en vous reconnectant en tant que Marine et 
en allant dans le menu Creer un contenu. 

Creer u n contenu 

Article 

Un article, similaire dans la forme a une pagt 
visiteurs a reagir, Revues de presse, actualits 
article e st automatiquement publie sur la pac 
commentaines. 

Billet 

Utilisezce type de contenu pourecrire un bil 
moins de 1 5 minutes. Si votne contenu est pk 


Ajout de types complexes 

Le module CCK 

L’ajout d'un contenu s’appuyant sur les champs standards de Drupal est 
une operation simple et directe. Mais lorsque le besoin de champs sup- 
plementaires pour un type de contenu a creer apparait, les choses 
deviennent un peu moins simples. 

A l’instar de la gestion des filtres, la gestion de nouveaux types de con- 
tenu plus specialises que Article ou Page sont delegues aux modules. 
Pour prendre en charge un nouveau type de contenu, vous pouvez des 
lors soit trouver un module qui reponde a vos besoins, soit en developper 
un qui soit parfaitement adapte a votre situation. Cette seconde solution 
est particulierement interessante pour ceux qui cherchent a creer un site 
professionnel et/ou a haut trafic, car cette approche est la plus efficace 
tant sur le plan des performances que sur celui de la souplesse d’adapta- 
tion a vos besoins reels. 
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Ceci etant dit, il existe bien evidemment une solution intermediate 
entre ce que propose Drupal et le developpement dun module 
personnalise : c’est le module CCK. 

CCK ( Custom Content Kit ) est un module tres imposant dont vous URL Module CCK 

entendrez parler a maintes reprises. Sa principale finalite est de per- . „ . ; : — . . . — 

, t v ,. r r . . r ► http://drupal.org/project/cck 

mettre 1 ajout de nouveaux champs a nimporte quel type de contenu. 

Une fois que vous l’avez telecharge et installe, dirigez-vous vers Tadmi- 

nistration des modules. 

Dans la section CCK , vous trouverez pas moins de neuf modules. Les 
modules principaux sont Content et Option Widgets, qu’il faut activer 
tous les deux. 

Nous avons ensuite une serie de modules dedies chacun a un type de 
champ : 

• Number pour les champs de type numerique ; 

• Text pour les champs de type texte ; 

• Node Reference pour les champs permettant de referencer des 
contenus ; 

• User Reference pour les champs refere^ant des utilisateurs. 

Activez l’ensemble de ces modules pour les besoins de notre exemple. 

Vous trouverez egalement les modules : 

• FieldGroup permettant de regrouper differents champs dans des sec- 
tions depliables comme celles que vous avez deja rencontrees ; 

• Content Permission qui permet de definir les droits d’acces au niveau 
dun champ ; 

• Content Copy qui propose d’exporter et d’importer les definitions de 
champs d’un serveur a un autre. 

II nest pas necessaire pour lmstant d’activer ces modules. D’une 
maniere generate - et on ne le repetera jamais assez n activez que les 
modules dont vous avez besoin. 


Creation du type de contenu Reference 

Pour mettre en oeuvre notre nouveau module CCK, nous allons creer le 
type de contenu Reference dont nous avons parle dans le chapitre « Bien 
definir son projet ». 



Reference 

-* 

Objet de le mission 

■t 

Date die la mission 


Prestation realisee 


Resultats obtenos 


Doma ine de 


competence 

* 

Acteurs 


Figure 8-40 

Definition du type de contenu Reference 
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Pour commencer, nous allons proceder exactement de la meme maniere 
que pour Taj out de type simple avec les informations suivantes : 

Nom : * 

Rife re nee ] 

Le nom affiche de ce type de conte nu. Ce texts sera affiche dans la liste sur la page creer un cor. 
commencer par une lettre majuscule et ne do it co nte n ir q ue des lettres, ch iff res, ete spaces. Ce r 

Type : * 

[reference ] 

Le nom interne de ce type de conte nu. Ce texts seia utilise pourcontmire TURL de la page creer 
type de contenu. Ce nom ne doit conte nir que des lettres minuscules, des ch iff res, etdescaiacte 
Les caiacteres de so u Ig ne me nt se ro nt co nve rtis e n tiain d' union bra de la contmction des URL d« 
contenu. Ce nom doit etre unique. 

Description : 

| Utilises ce type de contenu pour ajouter une nouvelle reference client 

Le reste du type de contenu se parametre comme une Page sans com- 
mentaires et sans fichiers attaches, avec Publication immediate mais sans 
l’option Promu en page d'accueil. 

Traitement des champs Titre et Corps 

Avant d’enregistrer, arretons-nous un instant sur la section Parametres du 
formulaire de contribution. Cette section permet de changer les libelles 
des deux champs standards de Drupal : Titre et Corps. 

II peut sembler astucieux de remplacer les libelles de ces deux champs 
par « Objet de la mission » et « Prestations realisees » : cela nous ferait 
moins de champs a aj outer avec CCK, et Ton s ’imagine deja que cela 
optimisera le stockage. Meme si cette demarche semble logique, elle 
n’en est pas moins dangereuse. 

II ne faut en effet jamais oublier que Drupal stocke ses champs dans des 
tables en base de donnees. Le titre et le corps sont stockes dans les tables 
node pour la premiere revision du document, puis node_revi sions pour 
les revisions suivantes. Les champs dans la table sont title pour le titre 
et body pour le corps. 

Pour des raisons de lisibilite - notamment le jour ou vous desirerez 
exploiter vos contenus avec d’autres outils que Drupal -, avoir des noms 
de champ sans aucun rapport avec ce qu’ils contiennent ne facilitera pas 
le transfert et la mise en place de vos donnees dans un nouvel outil. 

Lorsque vous creerez des champs avec CCK, ce module va automatique- 
ment generer une nouvelle table nommee content_type_reference qui 
contiendra un champ de base de donnees par champ CCK ajoute. La diffe- 
rence dans ce cas reside dans le fait que nous avons - comme nous le verrons 
plus loin - le controle sur le nommage du champ cree. Vous aurez done des 
noms de champ parfaitement coherents avec les donnees qu’ils contiennent. 
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Figure 8-41 

Saisie des informations decrivant 
le type de contenu Reference 


Dans le cas de notre type de contenu Reference, l’ideal serait de pouvoir 
supprimer ces deux champs standards litre et Corps pour creer ensuite 
l’ensemble des nouveaux champs personnalises. Le probleme est que si faire 
disparaitre le champ Corps ne pose aucune difficult^, Drupal n autorise en 
revanche pas qu un contenu n ait aucun litre (voyons cela comme Tune des 
rares limitations du produit). Nous ne pourrons done pas obtenir totalement 
leffet desire : il nous faut transiger en rempla^ant le libelle du champ Titre 
par Objet de la mission et en faisant disparaitre le champ Corps. 

Pour ce faire, dans la section Parametres du formulaire de contribution , il 
suffit de changer le libelle de Titre et de vider celui de Corps. 

V P arametre s d u fo rm u I ai re de co ntri b utio n 


Libelle du champ titre : * 

|Qbjetde la mission | 

Libelle du champ corps : 

Figure 8-42 

Pouromettre le champ corps pource type de contenu. supprimez le tejite et laissez ce champ vide. ModifiCdtiOPI dll libelle dll tire et SUppreSSlOPI dll COTpS 

Nous pouvons maintenant enregistrer notre contenu et passer a fajout 
des champs manquants. 

Ajout des nouveaux champs 

Peut-etre avez-vous deja note que factivation du module CCK a induit une 
legere modification dans la page Definition des contenus. Sur chaque ligne 
de la liste, nous avons a present une nouvelle operation : gerer les champs. 


R efe re nee refe re nee Utilisez ce ty pe de conten u pou r ajouter u ne nouvelle reference c lient 


gerer les 

modifier supprimer 

champs 


Figure 8-43 

La ligne correspondant a notre 
nouveau contenu 


Lorsque nous cliquons sur ce lien, nous arrivons sur une page qui nous 
permettra d’etendre le type de contenu comme nous fentendons. 

La premiere partie de la page nous donne la liste des champs actuelle- 
ment disponibles pour ce contenu. Il s’agit la des champs par defaut de 
Drupal et, comme prevu, le champ Corps a effectivement disparu de la 
liste et le champ Titre a ete correctement renomme. 


Etiquette Nom 

Objet de la 

Formulaire du module node. 

mission 


Parametres du 
menu 


Formulaire du module menu. 


Fichiers 

attaches 


Formulaire du module upload. 


Figure 8-44 

La liste des champs par defaut du type de contenu Reference 
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La partie Aj outer nous permet de creer de nouveaux champs. Nous allons 
commencer par Prestation realisee. 


Figure 8-45 

Ajout d'un nouveau champ 
au type de contenu 
Reference 


A jo uter 




Nouveau champ 




1 

j field_ [ 

[- Selectionnez un type de champ - C | 

- Selectionnez un widget - 

Etiquette 

Nom du champ fc-z, 0-9, _) 

Type de donneee a Stocker. 

Element du formubiie pourfedition des donnees. 


La premiere zone contient l’etiquette du champ, nous y saisissons done 
« Prestation realisee ». 

Dans la zone suivante vient le nom du champ. II s’agit d un nommage 
informatique qui ne doit contenir que des symboles alphanumeriques 
non accentues et eventuellement le symbole souligne. Saisissez 
prestation_realisee. Notez que cet identifiant precede du prefixe 
field_ servira de nom pour ce champ dans notre table 
content_type_reference. 

Suit une liste permettant de definir le type de donnees pris en charge par 
le champ. Dans notre cas, s’agissant dun simple texte, nous selectionne- 
rons done Texte. 

La derniere liste permet de choisir le composant (appele widget) per- 
mettant l’edition du champ : une Zone de texte conviendra parfaitement. 

Notre champ etant defini, appuyez sur Enregistrer pour passer au para- 
metrage du champ. 
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Figure 8-46 

Definition du fonctionnement 
du champ Prestation realisee 


Parametres de 'Reference' 

Ges para metres nes'applquequ'ou champ 'Rre 

Rangees : 



Texte d' nide : 

Decrivez ici la pne station realisee| 


Ici peu de choses sont a modifier, si ce nest le nombre de lignes (Ran- 
gees ) du champ, un Texte d'aide pour le contributeur a propos de ce 
champ, et son caractere obligatoire en cochant la case Obligato ire. 


Figure 8-47 

Ce champ est obligatoire. 


Parametnes globaux 
Ges parametres s'appliquentau c 
0 Obligatoire 


Ceci fait, appuyez sur Enregistrer les parametres du champ pour creer 
effectivement le nouveau champ. 
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Repetez l’operation pour le champ Resultats obtenus qui lui aussi est un 
champ texte avec un controle de type Zone de Texte. 

Ajout d’un champ multiple 

Le champ suivant a ajouter est Acteurs. II s’agira cette fois de saisir non 
plus une valeur simple, mais une liste d utilisateurs dont la longueur est 
variable. 

Ajoutons pour commencer un champ, Acteurs , qui cette fois, a pour type 
User reference , c’est-a-dire quil contiendra un nom dutilisateur. Dans la 
liste des controles, nous utiliserons Champ texte a auto 'Completion , un 
controle sympathique permettant de retrouver un utilisateur en tapant 
seulement les premieres lettres de son nom. 

•f Nouveau champ 

|Acteurs | field [acteurs | | User reference 

Etiquette Nom du champ (a-z, 0-9, _) Type de donneea a Stocker 

Dans les parametres du champ, nous allons d’abord remplir les champs 
habituels ( Obligatoire , Description , etc.) et nous interesser de plus pres au 
champ Nombre de i/aleurs. 

Ce champ determine combien de valeurs il sera possible d’ajouter dans 
notre champ Acteurs. Jusqu a maintenant, cette option avait ete laissee a 7, 
indiquant quune seule valeur etait possible. Mais comme nous pouvons 
avoir pour ce champ une serie d utilisateurs, cela ne conviendra pas. Nous 
allons done selectionner I Hi mite, ce qui nous permettra d’aj outer autant 
d’acteurs que necessaire. 

Nombre de valeurs : Figure 8-49 

[ iiiimite c | Champ Nombre de valeurs positionne sur lllimite 


| Champ teste a auto-complete me nt C | 
Element du formula in? pour fed Hbn dee donneea. 


Figure 8-48 

Ajout du nouveau 
champ Acteurs 


Entre 7 et lllimite, il nous est possible de choisir un nombre fixe de 
valeurs. Ceci est utile lorsque nous connaissons a l’avance le nombre 
maximal de valeurs possibles, ce qui n est pas le cas ici. 

La derniere chose que nous allons modifier ici est lactivation de la reference 
arriere (ou retrolien) sur lutilisateur. Le principe est que tout acteur qui sera 
ajoute dans ce champ verra sa page de profil enrichie par la liste des contenus 
auxquels il a participe. Cochez pour cela loption Lien retour. 

ct) , . Figure 8-50 

cLi Lien retour 

si cette option est eeiectjonne. Activation de I'option Lien retour 


185 


www.frenchpdf.com 


Creer des contenus 


Drupal 6 - Concevoir et deployer ses applications 


£ 


Notre champ multiple est maintenant pret a etre utilise, nous pouvons 
l’enregistrer pour passer au dernier champ, la date de la mission. 

Ajout d’un type de champ 

Le probleme est que CCK ne dispose pas dun type de champ Date en 
standard. Mais CCK est un veritable ecosysteme a lui tout seul. II existe 
ainsi de tres nombreux modules de contribution dont leur seul objectif 
est d’etendre ses fonctionnalites en ajoutant un type de champ, un mode 
d’affichage, etc. 

URL Module Date Pour la gestion des dates, le module a installer s’appelle tout simplement 

Date 

► http://drupal.org/project/date 

Au moment de l’activer, vous constaterez que Date, comme CCK, est un 
module assez complexe permettant de gerer a peu pres tous les aspects 
dun calendrier. Comme CCK, il est compose de nombreux sous- 
modules. II convient de tous les activer a l’exception de Date PHP4, qui 
n’a d’interet que si vous utilisez encore une version 4 de PHP 

Une fois le module Date active, vous pouvez retourner sur la page Gerer 
les champs du type de contenu Reference. Vous constatez alors que la 
liste des types de champs s’est etoffee d une serie de formats de date. 

Nous pouvons a present creer notre champ Date de la mission avec comme 
identifiant date_mi ssi on. Vient alors le choix du type de champ qui merite 
un peu d’attention, car nous avons ici trois formats differents : 

• Date est a proscrire car il consiste a Stocker une chaine de caracteres 
representant la date voulue. Ce format sera difficile a exploiter par 
d’autres applications que Drupal. Mais surtout, il mine les perfor- 
mances de toutes les listes que vous pourrez faire en utilisant cette 
date comme critere ; 

• DateTime utilise quant a lui le type specifique Date de votre base de 
donnee. Cette approche est compatible avec une utilisation externe 
des donnees, mais pas avec le reste de Drupal qui manipule difficile- 
ment ce format ; 

• Datestamp a favantage d’etre simple a manipuler par d’autres applica- 
tions et nativement utilisable par Drupal. Toutes les dates de Drupal 
sont deja stockees dans ce format (ex. la date de creation ou de mise a 
jour d’un noeud). C’est en fait un timestamp Unix (appele aussi epoch 
Unix), c’est-a-dire qu’il indique le nombre de secondes ecoulees entre 
la date indiquee et le l er janvier 1970. C’est le choix qui vous est con- 
seille. 

Une fois le type de champ Datestamp selectionne, reste a choisir le controle 
qui permettra de l’editer. Le Champ Texte avec Pop-up Date est une solution 
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agreable et elegante permettant aussi bien une saisie manuelle et directe de 
la date que lutilisation d un petit calendrier pour une selection visuelle. 


A jp uter 


* 

Nouveau champ 

Date de la mission 


field_ date_mission 


Date stamp 


| Champ Texte avec Pop-up Date 


Norn du champ fc-z, 0-9, . 


Type de donnees a stacker. 


Element du formulaiie pour Ted rtio n dea donneea. 


Figure 8-51 Creation du nouveau champ Date de la mission 


II ne reste plus qu a valider pour passer au parametrage du champ. 

Dans le parametrage, nous avons ici davantage d’elements a changer. 
Au-dela des classiques ligne d’aide et champ Obligatoire, il est pertinent 
d’ecarter la gestion de l’heure et du jour pour ce type de date, car ils pre- 
sented peu d’interet dans le contexte. Pour cela, selectionnez seulement 
Annee et Mois dans la zone Granularite. 


i 

00 


Gra nub rite : 


Annee 

Mois 

L 

Jour 


Heure 


Minute 


Seconde 



Figure 8-52 

Seuls les annees et les mois comptent... 


Comme nous ne prenons pas en compte l’heure, nous desactivons aussi 
la Gestion desfuseaux horn ires : 

Gestion des fuseaux ho ra ires : Figure 8—53 

I Pas de conversion de tuseau, horaires s~ | Avec seulement des mois et des annees, 

Selectionnez la methode a utilfee r po u r la geation dea fu le fuseau horaire est inutile. 


Voila, notre champ est maintenant pret, nous pouvons done l’enregistrer. 

Ordonnancement des champs 

A chaque fois quon termine Tenregistrement dun nouveau champ, 
CCK nous transporte sur la page Gerer les champs avec une liste de 
champs visibles. Les champs sont pour l’instant classes dans l’ordre de 
leur creation, mais il est cependant possible via le systeme habituel de 
glisser-deposer de les deplacer pour les mettre en accord avec ce 
qu’attend le contributeur. 
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Figure 8-54 

Les champs, une fois reorganises 


Etiquette 

Nom 

Type 

* 

Date de la mission 

field_date_mission 

Date stamp 


Objetde la mission 

Formulaire du module node, 


4 

P re station Realisee 

fie Id p re statio n_re al i see 

Texte 

4 

Resultats Obtenus 

fie ld_re s u ltats_o bte n u s 

Texte 

4 

Acteurs 

field_acteurs 

User reference 

+1* 

Parametres du menu ' 

Formulaire du module menu. 



Lorsque l’ordre des champs vous convient, enregistrez Tensemble pour 
finir. 

Affichage des champs 

Nous avons jusqu a present travaille sur l’aspect d’edition de notre type 
de contenu Reference ; il est temps d’envisager ce qui sera affiche pour 
les visiteurs du site. Pour ce faire, cliquez sur l’onglet Afjicher les champs. 

Sur cette nouvelle page il est possible de definir precisement la maniere 
dont un contenu sera affiche, selon le type de rendu (basique, lors dun 
resultat de recherche, dans un flux RSS), ainsi que le mode de rendu 
(contenu complet ou abrege). 

Les types de rendu sont selectionnables via les sous-onglets Basique , 
Recherche et RSS. Dans un premier temps, travaillons sur le type de rendu 
Basique, qui correspond a notre usage pour le moment. 

Nous disposons ici de la liste des champs definis via CCK. On notera et 
regrettera l’absence du champ Titre que nous avons renomme et qu’il 
nest pas possible de parametrer ici. 

• La premiere colonne permet de changer la position de fetiquette du 
champ. Nous laisserons ces valeurs a Au dessus sauf pour la date, un 
champ court, ou nous prefererons Sur la meme ligne. 

• La seconde colonne determine f affichage du contenu dans son mode 
abrege. Nous allons ici tout cacher (<Hidden>) sauf pour Prestation 
realisee. 

• La colonne Noeud Complet definit cet affichage pour le mode complet. 
Laissez les valeurs par defaut pour les deux champs texte, et choi- 
sissez le format Short (court) pour la date. 

Une fois le format d’affichage defini, il est temps de tester notre nouveau 
type de contenu. 
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00 


Figure 8-55 Parametrage du mode d'affichage de chaque champ 

Creation d’un contenu Reference 

Nous avons decide de ne pas donner les droits sur ce type de contenu aux 
contributeurs, seul Tadministrateur y a done acces. Nous allons tester 
cela en cliquant sur Creer un contenu , puis Reference. 

Le formulaire sutilise ici de la meme maniere que dans le cas des autres 
types de contenu, avec toutefois les specificites ajoutes par CCK et Date. 


Champ 


Etiquette 


Date de la mission Sur la meme ligne 


Prestation Realisee ‘ Au dessus 


Resultats Obtenus Au dessus 

Acteurs 


Sur la meme ligne C ! |<Hidden> 


Exclure Nceudcomplet 

□ | Short 

□ | Pardefaut C 

□ | Pardefaut C 

EH I Pardefaut C 


Exclure 

□ 

□ 

□ 

□ 


Objet de la mission : 4 

[Recrutementd'un equipe Exploitation pour une grande bang Lie Allemande 


Date de la mission : 4 


1 06.20 09| 

1 



^ Juin 

- 2009 - ► 

□1 LU MA 

ME JE VE SA 



1 

2 

3 

4 

5 

6 

7 

8 

9 

10 

11 

12 

^ oil en un temps record d'un equipe dediees a Hexplc 

14 

15 

16 

17 

18 

19 

20 

21 

22 

23 

24 

25 

26 

27 

28 

29 

30 





1 


Dec rives ici lap restate n realisee 

Resultats Obtenus : 4 

Ms sonttous ties bon, et le client semble satisfait, du moins pour I'instant... 


Figure 8-56 

Le champ Date de la mission et son calendrier en action 


Pour notre champ a valeurs multiples ( Acteurs ), nous disposons bien de 
tous les elements necessaires a sa gestion. II est aussi possible de gerer 
l’ordre des champs : 


| Marine 

0 


| Karine 

0 


* r 

0 

Figure 8-57 

| Ajouter un autre element 


Ajout d'un nombre illimite d'acteurs 
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Vous pourrez etre surpris a juste titre par l’absence de bouton Supprimer. 
Le fonctionnement id est qu’une valeur vide est une valeur detruite. Si 
vous enlevez cette valeur, le champ sera automatiquement supprime. 

De meme, on pourrait s’etonner qu il y ait deux champs vides par defaut. 
C’est un comportement voulu de CCK et non pas un probleme lie a 
votre parametrage. 

Une fois le contenu saisi, vous pouvez l’enregistrer pour juger du rendu 
final en mode complet. 

Recrutement d'un equipe Exploitation pour une grande banque 
Allemande 


Voir 


Figure 8-58 

Le contenu de type Reference 
une fois enregistre 


3juin 3009- 1:42pm — administiateur 

Date de in mission: 07:2009 
Prestntion Realisee: 

La mission a consists en la constitution en un temps record d'un equipe dediee a I 'exploitation du systems 
Inform atique d'une grande banque allemande. 

ResuKats Oblemts: 

lls sont tous ties bons . et le client semble satisfait, du moins pour I'instant... 

Acteurs: Marine 
Karine 


Nous avons la toutes les informations saisies dans chacun des champs 
supplementaires. Nous pouvons maintenant verifier faffichage en mode 
abrege sur la page d’accueil. 


Figure 8-59 

La version resumee d'un contenu 
de type Reference 


Recrutement d'un equipe Exploitation pour une grande 
banque Allemande 

3juin 2009- 1:42pm — admin is trateur 

Prestation Realises: 

La mission a consists en la constitution en un temps record d'un equipe dediees a 
I 'exploitation du systems informatique d'une grande banque allemande. 


Attention 

CCK r PostgreSQL et les revisions 

Dans la version courante de Drupal 6, il y a un bug 
encore non corrige pour PostgreSQL et quelques 
configurations de MySQL, qui empeche la sauve- 
garde d'un contenu CCK avec les revisions acti- 
vees. Plus d'informations sur cette anomalie id : 

► http://drupal.org/node/261258 


Tous les champs que nous avons decides de cacher sont effectivement 
invisibles : fensemble est satisfaisant. 

Les limites de CCK 

CCK est un excellent module, indispensable a l’ecosysteme Drupal. 
Malgre tout, il est important de garder la tete froide et, avant de se 
lancer, de mettre son utilisation en balance avec son alternative naturelle, 
la redaction de vos propres modules de gestion d un contenu. Dans cet 
esprit, et avant tout pour des sites de taille importante, les points sui- 
vants sont a prendre en compte. 
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Performances 


Pour les personnes qui auraient un mauvais souvenir de ce module sous 
Drupal 5, les problemes de performance de CCK sont aujourd’hui une 
chose reglee avec Drupal 6. 

Deployment 

CCK vous oblige a passer par une procedure manuelle de copier-coller 
pour exporter vos types de contenu, puis pour les importer sur votre ser- 
veur de production. Contrainte supplementaire, les types de contenu ne 
sont pas exportables d un coup, vous obligeant a operer type par type. 
Enfin, si un nouveau champ peut etre ajoute par ce moyen, il ne peut en 
aucun cas etre supprime ou modifie. Ceci explique que la majorite des 
administrateurs font ce type d’operations eux-memes, en repetant leurs 
manipulations sur le serveur de production. 

Si le type de contenu etait gere par un module, il aurait suffit de recopier 
le code de sa nouvelle version et d’operer une mise a jour de la base 
Drupal pour que le deployment soit realise (voir le chapitre 15 sur le 
deployment) . 

Mise a jour 

CCK n autorise pas la modification du type d un champ (par exemple, 
changer un entier en chaine de caractere), ce qui dans certains cas se 
revelera tres genant, vous amenant la aussi a gerer la migration de vos 
donnees « a la main ». 

A contrario, pour un module, il suffit de developper des procedures de 
mise a jour, de les tester sur la plate-forme de developpement avant de 
repeter foperation sur le serveur de production. 

Maitrise des donnees 

Comme nous favons vu avec les champs de type Date, il faut etre tres 
prudent en choisissant un type de champ CCK, et toujours s’assurer de 
la pertinence des types auxquels ils correspondent en base de donnees. 
Un mauvais choix (comme le type Date au lieu d un Datestamp) peut 
impliquer une perte importante en termes de performance. De plus, cer- 
tains types de champs fournis pas des modules externes a CCK peuvent 
stocker les donnees dans un format difficilement exploitable par une 
requete SQL. Limportant est done de toujours verifier ce que CCK fait 
sur la base de donnees, et si cela vous convient. 
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Creer des listes de contenus 

Lorsque Ton con^oit un site, un des besoins recurrents est l’affichage de 
listes de toutes sortes et a tout crin : 

• liste des derniers commentaires ; 

• liste des dernieres activites (creation de noeuds, de commentaires, 
d utilisateurs) ; 

• liste des contenus non publies, etc. 

Rien ne permet en standard dans Drupal de creer de telles listes, mais 
comme souvent, la fourniture de ce type d’affichages est en realite assuree 
par des modules, et les nombreuses listes que nous avons deja abordees 
sont issues de tels modules (liste des utilisateurs, des commentaires, etc.). 
Vous avez ici la possibility d ecrire votre propre module pour afficher des 
listes, et Drupal offre toute une boite a outils permettant de le faire sans 
probleme majeur (gestion des tris, de la pagination, etc.). II existe egale- 
ment des modules de contribution specialises dans cette fonction, qui 
pourront deja combler bon nombre de vos besoins en ce domaine. La regie 
est toujours la meme : le module doit etre le choix prioritaire, et ce choix 
est d’autant plus pertinent qu’il est rare que votre besoin n ait pas deja ete 
celui de beaucoup d’autres personnes avant vous. 

URL Module Views Cependant, si vous ne trouvez pas le module de vos reves, il existe un 

— r ~ — — ; : — : — rr^ outil capable de generer n importe quelle liste : il s’agit du module 

► http://drupal.org/project/views . . & n , v . ^ « 

Views, qui est a peu pres aussi celebre que CCK dans 1 umvers Drupal. 

Comme pour CCK, il se compose de plusieurs modules : 

• Views, le module principal qui gere la mecanique interne ; 

• Views UI, indispensable pour creer des vues ; 

• Views Exporter, qui permet d’exporter et d’importer des vues d un 
serveur a l’autre. 

Apres l’avoir installe, activez simplement, pour 1’heure, les deux premiers 
modules. 

Creation des vues Articles et Billets 

Deux listes vont nous etre particulierement utiles pour implementer nos 
deux sections Articles et Billets. Elies n ont rien de bien sorcier, car il s’agit 
simplement de filtrer respectivement les contenus de type Article et 
Billet, puis de les classer par ordre decroissant de date de creation. Pour 
creer ces listes, rendons-nous dans Construction du site > Vues. 

Cette page donne la liste des vues actuellement disponibles. Celles appa- 
raissant en grise sont des vues automatiquement gerees par le module 
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Views. Nous y reviendrons un peu plus loin. Pour l’heure, nous allons 
creer notre premiere vue en cliquant sur l’onglet Ajouter. 


Vues 


Liste 


Importer 


Outils 


Nom de b vue : * 

[liste_des_publications ] 

II £agit du nom unique de la vue. II ne do it co mpo rte r q ue des caracteres a^i han u me riq uea et des 
spaces so u lig nea. II aert a identifier ^ vue en interne et a geneierdea noma uniquea pour lea 
templateade the mea pour cette vue. Si la vue aupplante une vue fdumie parun module, le nom ne 
doitpaaetie modifie aous peine de cieerune nouvelle vue. 

Description de la vue : 

[Liste des publications ] 

Cette desorption appaiaitia dana T interface utilEateurd'adm initiation de V ievra po u r vo ua indiquer 
Tobjet de cette vue. 

Etiquette de b vue : 

jListe des publications! 

Saiiaez une etiquette optionnelle pour cette vue ; e lie aert uniquement a faciliter le tri dea vuea sur 
la page d'ad m in iatratio n . 

Type de vue : 

® Noeud 

Lea naeuda constituent le contenu primaire d'un site Drupal. 

O Commentaire 

Lea co m me ntaires ao nt des leponaea au contenu dea nceuda. 

O Fichier 

Fichieia maintenua par Dmpal et diffe rents modules. 

O Locale source 

A source string fb r transitio n , in English or the default site language. 

O Revision du noeud 

Lea ibvsions du noeud represents Thistorique dea modifications de ce noeud. 

' - ' Terme 

Lea termes de taxonomie aont rattaches aux nceuda. 

O Utilisateur 

Utilisateuis ayant cree un compte aurvotre site. 

Le type de vue eat la table primaire pour ique lie lea info rmatio ns ao nt recupeiees. Le type de vue 
controls q ue la arg u me nts. champs, criteres de tri et fifties ao nt d ispo n b lea ; par consequent, une fos 
qu'il eat fixe, il ne peut plus etre modlfle. 


| Suivant | 


Figure 8-60 

Definition de la vue 


i 

00 


Ce formulaire nous permet de definir le Nom de la vue (un nom informa- 
tique, done sans accents ni espaces), sa Description et une Etiquette qui ne 
sera utilisee quen interne. Ces champs prendront respectivement les 
valeurs 1 i ste_des_publ i cations, Liste des publications et Liste des 
publ i cati ons. 

Pensez a donner des descriptions explicites, car des quun nombre 
important de vues sera cree, elles seront vos seules aides pour ne pas vous 
noyer dans vos vues. 
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Bon A SAVOIR Que signifient les sections 
de Views en langage SQL ? 

Pour ceux qui connaissent un peu SQL, nous pou- 
vons illustrer le role de ces blocs de la maniere 
suivante : 

SELECT <Champs> 

FROM <objet de base defini plus 
haut> 

JOIN <Relations> 

WHERE <Fil tres> 

ORDER BY <Cri teres de tris> 
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Ensuite vient le Type de i me qui determine sur quel type d’objets la vue 
portera. Attention, une fois selectionne, le type d’objet ne pourra plus 
etre change. Nous allons ici afficher une liste de noeuds, selectionnons 
done Noeud , avant de cliquer sur Suivant. 

Fonctionnement de Views 

Meme si de tres bonnes idees ont ete developpees par hauteur de ce 
module sur le plan de l’interface graphique, elles ont malheureusement 
aussi le defaut de ne pas suivre les regies en vigueur dans Drupal. L’inter- 
face de Views demande done a etre apprise dans ses specificites. 

Nous arrivons a present sur la page imposante - voire impressionnante - 
de parametrage de la vue. Quelques explications sur les blocs que nous y 
trouvons : 

• Parametres de la vue reprend les informations que nous venons de 
saisir, ou plutot la seule que nous pouvons encore modifier, a savoir 
YEtiquette ; 

• Parametres de base contient toutes les informations necessaires a la 
production finale du resultat (style, mise en forme, limitation d’acces, 
etc.). 

Les cinq blocs suivants permettent de construire la requete qui, elle-meme, 
produira la liste : 

• Relations definit des elements provenant d’autres objets que celui que 
nous avons defini comme objet primaire sur la requete ; 

• Arguments fait reference aux elements variables de la requete qui 
seront extraits du chemin interne ; 

• Champs designe les champs qui seront visibles ; 

• Filtres definit les conditions de la requete ; 

• Criteres de tri presente les champs sur lesquels un tri doit etre opere. 

Construction de la liste 

Puisque nous cherchons a creer une liste d’articles, la premiere chose a 
faire est done d’ajouter un nouveau filtre. Pour cela, utilisez le bouton + 
du bloc Filtres. Vous verrez alors la zone basse du formulaire changer 
pour vous permettre de definir le champ a filtrer : nous allons selec- 
tionner le type de noeud Noeud : Type. Si vous avez du mal a vous y 
retrouver, vous pouvez utiliser l’option Groupe qui permet de nafficher 
que les champs pour un type d’objet donne (ici, Noeud). 
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Para metres par defaut: Ajouter filtres 
Croupes : 

Noe Lid fj 

Whetheror not the node is published. 

□ Noeud : Publie ou admin 

Filtre et eaclut les noeuds non pub lies si T utilisate u r co u rant ne peut pas les voir. 

□ Noeud : Publie ou commente par I'utilisateur 

Display nodes only if a user posted the node o r co m me nted on the node. 

□ Noeud : Resume 

Le champ du resume enregistre. Cecipeut ne pasetie valide ou utile pour to us les 
types de noeuds. 

□ Noeud : Statutdes commentaires 

Indique si les co m me ntaiies so nt actives ou desactives sur le noeud. 

□ Noeud : Titre 
Title du noeud. 

© Noeud : Type 

Type d'un noeud (par eae mp le , "billet de blog", "discussion de forum", "article", 
etc.). 

|Ajouter| |Annuler| 


Figure 8-61 

Ajout d'un nouveau filtre 


i 

00 


Cliquez ensuite sur Aj outer, et le bas de la page devrait changer pour per- 
mettre de modifier les parametres du filtre. 


Para metres par defaut: Configure filtre Noeud; Type 


Get element n'est pour le moment pas expose. Si vous I'exposez. les 
utileateurs pournont changer le filtre lorsqu'ils llaffichent. 


Exposer 


Ope rate ur : 

® Faitpartiede 
1 Ne fait pas 
partie de 


Type de noeud : 

□ Billet 
U Book page 
HH Page 
U Reference 
U Newsletter issue 
!©1 Article 


a jour | | Annuler | | Oter | 


Figure 8-62 

Parametrage du filtre sur les types de contenu 


En toute logique, nous choisissons ici Article et validons par le bouton 
Mise a jour. Ajoutons a present le critere necessaire pour nafficher que 
les contenus publies. Pour cela, nous renouvelons l’operation d’ajout avec 
cette fois-ci le champ Noeud : Publie et selectionnons la valeur Oui. 

Nous allons terminer le bloc Filtres en ajoutant maintenant le critere 
Publie en page d'accueil. Pour cela, nous allons ajouter un dernier filtre sur 
le champ Noeud : Promu en page d’accueil. Et pour valeur, nous utilisons 
Oui. Le bloc de filtres est maintenant complet. 


Filtres + t+j 

Noeud : Type = Article 
Noeud : Publie Oui 

Noeud : Piomu en page 
d’accueil Oui 
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Presentation de la liste des filtres 
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L’etape suivante consiste a ajouter le tri qui permettra d’afficher nos con- 
tenus par ordre decroissant de date de creation. Pour cela, cliquez sur le 
bouton d’ajout du bloc Criteres de tri et choisissez Node : Date de mise a 
jour , puis Ajouter. Vous pouvez alors parameter le tri. Nous choisirons 
un ordre Descendant (du plus recent au plus ancien) en laissant la granu- 
larity a Seconde. Cliquez ensuite sur Mise a jour. 


Figure 8-64 

Presentation des criteres de tri 


Criteres de tri + F+l 

Node : Date de miss a |oui desc 


Bon A SAVOIR Views pour les developpeurs 

En tant que developpeur de module, il n'est pas 
toujours facile de savoir comment construire une 
requete SQL qui fasse appel aux donnees de nom- 
breux modules. 

Views est assez pratique dans ce cas de figure, car 
en dessous de I'apergu, vous trouverez la requete 
SQL qui I'a amene a construire son resultat. II suffit 
alors de la copier dans son code et de la nettoyer 
un peu. Ainsi, sans aller jusqu'a creer des vues, 
Views est une tres bon aide au developpement de 
modules. 


Notre requete ne comportant ni arguments, ni relations, ni meme de 
champs, notre parametrage de la requete SQL s’arrete done ici. En effet, 
nous cherchons simplement a afficher une liste de noeuds, et nous la pre- 
senterons avec tous les champs que Drupal expose habituellement pour 
ce type d’affichage en liste. C’est dans le bloc Parametres de base que 
nous allons a present indiquer ces choix. 

• litre : nous devons changer ce champ pour une formulation plus 
explicite, telle que « Nos dernieres publications ». 

• Style : nous selectionnons Non mis en forme, laissant cela au moteur de 
theme de Drupal. Vous avez ici la possibility de generer un tableau ou 
une grille selon vos besoins. 

• Style de ligne : nous avons deux possibilites, Noeud ou Champs. Nous 
selectionnons Node pour un affichage simple des noeuds comme 
Drupal le fait d’ordinaire (par exemple, sur la page d’accueil). Dans 
les options proposees, nous choisissons Resume pour n afficher qu une 
version abregee de l’article, puis cliquons sur Mise a jour. 

• Utiliser la pagination : choisissez Pagination complete. Vous pouvez 
regler le nombre de noeuds a afficher par page avec le champ suivant : 
Elements par page. 

Notre vue est maintenant prete a etre utilisee et vous en avez normale- 
ment deja un aper<;u en bas de la page. 

Letape suivante consistera a creer une page a partir de ces Parametres par 
defaut. Cette operation est realisee par la creation d’un nouvel affichage 
de type Page et, pour ce faire, selectionnez Page dans la liste de fonglet 
vertical a gauche, avant de cliquer sur Nouvel affichage. 


Figure 8-65 

Ajout d'un affichage de type Page 


Parametres par 
defaut 


Page 0 1 

Nouvel affichage 
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Ceci fait, cliquez sur l’onglet Page qui vient d’apparaitre. 


Parametres par 
defiaut 


Page 

► 


Figure 8-66 

Selection de I'onglet de type Page 


Le bloc qui nous interesse ici est Parametres de la page : il nous permettra 
de definir le chemin interne de la vue et eventuellement de creer un menu. 
Seule la premiere possibility nous interesse pour l’instant. Cliquez sur 
Chemin : aucun et saisissez maintenant le chemin publ i cati ons. Notre vue 
sera ainsi disponible par 1TJRL http://www.colchique-conseil.fr/publications. 


i 

00 


Page: Le chemin ou I'URLde menu pour cette vue 

http Jhi ww .co Ic h iq ue-co n se i I .f r/ 

[publications! ] 

Cette vue seie affichee en VEitant ce chemin survotie site. Vo us pouvez utilise r"%" dans 
votie U R L po u r lep lese nte r les vale u is qui seiont utilisees com me arguments : parexemple 
" nodefflyfaed 1 ' . 

Figure 8-67 

| Miseajoui'l [ Annuier ] Definition du chemin d'acces a notre liste 


Tester I’affichage 

Cliquez sur Mise a jour pour valider les changements, puis sur le bouton 
Enregistrer. La vue est maintenant prete a etre utilisee. Pour la tester, cli- 
quez sur le lien Voir « Page » en haut du formulaire. 

Bienvenue 

mar, 06/02/3009 - 23:38 — Marine 
Bienvenue sur le site de Colchique Conseil. 

le cabinet de conseil en ressources humaine qui a \'Sthique a coeur . 


En savoir plus 2 fichiers attaches 


Un nouvel article 

ven, 06/05/2009- 16:20— Marine 
Gorps de I'article... 

Figure 8-68 

Ajouter un commentaire Presentation de la liste des articles 


Nous voila avec une liste en tout point semblable a la page d’accueil, 
mais pour les seuls conte nus de type Article. 
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Duplication de vues 

Pour creer la meme vue, mais cette fois-ci appliquee aux Billets, l’opera- 
tion sera beaucoup plus rapide. Retournez dans la liste des vues, et a la 
ligne de notre vue Articles, cliquez simplement sur le lien Dupliquer. 


Figure 8-69 

Notre vue liste_des_publications dans la liste 
des vues, point de depart pour la duplication. 


Vue Normal Noeud : liste_des_publications (Liste 
des publications) 

Titre : Nos dernieres publications 

Ghemin : publications 

Page 


Modifier | Exporter | Dupliquer | Supprimer 
Liste cfcs publications 


Cette operation a pour effet de creer une nouvelle vue identique a notre 
vue Articles, nous faisant ainsi gagner beaucoup de temps. II va cepen- 
dant falloir la modifier en commen^ant par changer les valeurs en 
liste_des_bil lets, Liste des Bi 1 1 ets et Li ste des Bi 1 1 ets, avant de 
cliquer sur Suivant. Vous aboutissez alors sur la page d’edition de la vue, 
prechargee avec tout ce que nous avons deja parametre. 

Les trois seules choses devant etre changees sont : 

• le Titre : dans le bloc Parametres de base , a changer par « Nos derniers 
billets » ; 

• le filtre sur Noeud : Type : il suffit pour cela de cliquer sur la valeur, de 
decocher Article pour cocher Billet, et enfin de cliquer sur A/1 ise a jour ; 

• le Chemin de la page : selectionnez l’affichage Page, et changez le 
Chemin comme nous l’avons fait pour la precedente vue en utilisant la 
valeur billets. 

II ne vous reste maintenant plus qua enregistrer la nouvelle vue puis a la 
tester comme precedemment. 


Les performances de Views 

Lutilisation de Views sur de gros projets est a envisager en connaissance de 
cause. II ne s’agit pas de critiquer gratuitement cet excellent module, mais 
plutot de bien comprendre que son extreme souplesse de parametrage se paye 
en termes de performances. La raison de cet etat de fait est que Views est 
oblige a chaque fois de lire dans la base de donnees pour fabriquer sa requete 
SQL et de travailler en collaboration avec dautres modules, pour finalement 
produire son resultat. Pour donner un rapport de grandeur, la oil un module 
« simple » affichant une liste lancerait logiquement une seule requete pour 
produire un rendu visuel, Views va en lancer environ huit (comprenant aussi 
des requetes en ecriture), en mettant finalement le double du temps. 

Views est done un outil tres utile et d une grande souplesse, mais il hen 
demeure pas moins lent et done a envisager avec precaution sur des pages 
fortement sollicitees, et plus particulierement si vos utilisateurs sont majori- 
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tairement identifies (pour plus d ’informations, se reporter a la section sur les 
performances dans le dernier chapitre, « Mettre son site en production »). 


Etendre le modele de droits 

En standard, Drupal propose une gestion des droits d’acces fondee sur les URL Module Node Access 

roles affectes a un utilisateur. Mais cela peut se reveler insuffisant dans de . .. . ; : — . 

, . , A . r . i . v i • ► http://drupal.org/project/nodeaccess 

nombreuses situations, ou netre tout simplement pas adapte a vos besoms. 

Le systeme standard de droits d’acces est bien evidemment totalement 

extensible via des modules qui apporteront d’autres visions sur le sujet. 

Enumerer l’ensemble de ces modules serait long et inutile, car il s’agit 

avant tout de couvrir vos besoins. Nous allons simplement nous attarder 

sur un module particulierement representatif, appele Node Access. 

Le module Node Access permet de definir des droits pour un contenu 
specifique. Ces droits viendront completer les droits par role de Drupal. 

II sera ainsi possible, pour un seul contenu, non seulement d’ajouter de 
nouveaux roles autorises a le visualiser, a le modifier ou a le supprimer, 
mais plus interessant encore, d’ajouter des utilisateurs qui n’avaient pas a 
l’origine un role donnant acces a ce contenu. 

En allant dans Gestion des utilisateurs , puis Node Access, vous avez tout 
d’abord la possibility de definir les types de contenu qui beneficieront de 
cette nouvelle gestion des droits, ainsi que les permissions par defaut 
associees a chaque role pour un type de contenu donne. 


01 


Show grant tab tor this node type 


Role 

Voir 

Modrtie r 

Supprimer 


utilfsateur anonyms 

0 

□ 

□ 


utilisateur idenlifie 

0 

□ 

□ 


contribute ur 

0 

0 

0 


corrects ur 

□ 

□ 

□ 


valid ate ur 

□ 

□ 

□ 


A other Settings 

Voir 

Modifier 

Supprimer 


Node author 

0 

0 

0 

Figure 8-70 

The seining selected Tor th= nol? author wK del Ire a hat permfistins the node auihor h^. 

T tit cannot b? c hanged coi Inotv tlol nod? giants. 

Parametrage des permissions 
par defaut par type de contenu 


Dans cet exemple, nous ne faisons que reproduire le comportement 
standard de Drupal et de nos reglages de roles. 
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Plus loin, vous pourrez egalement choisir les roles autorises a recevoir des 
droits speciaux, par exemple authentificated user (Utilisateur identifie). 


Figure 8-71 

Selection des roles ayant des 
droits sur les contenus 


U Allowed Roles 

The seise tad rates will be Is ted on mdiv dual rede grarts. Jr you we h tor certain rales bo be hdden I ram leers on I It node grants li±a, mdteaise 
pro.'de an ate tor each rots lobedEpteysd to the LEsr ant a weqhl to order them by. The e raelut it your rote hroe machine- reacted names 

Allow Role Alias 


d anonymous user 
0 authentic abed user 
U conlributeur 
Id cornecteur 
Id validate ur 


I hey are ml sete bed btie. You may aba 
nab intended tor human lEers. 

Raids 


u 


0 


0 


0 


0 


Une fois le parametrage enregistre, le module Node Access affiche un 
message indiquant que la table des droits doit etre reconstruite. Suivez le 
lien et reconstruisez la table. 


Figure 8-72 

Message demandant la reconstruction de la 
table de droits sur les contenus 


Les permissions d'acces au contenu doiventetre recon struites. Veuillez vous rendre sur cette page. 


Ceci fait, pour un type de contenu donne - Article, dans le cas present -, 
le module va ajouter un onglet Grant disponible pour chaque contenu. 


Figure 8-73 

Apparition de Tonglet Grant, permettant de Bienvenue voir Modifier Revisions 

definir les droits sur un contenu 


Figure 8-74 

Assignation des droits de modification 
a I'utilisateur Pierre, qui 
n'est pas un contributeur 


Enter names to search for users: 

| Pierre 

Utilisateur Keep? 

Pierre 0 


O | Recherche j 

Voir 

0 


Modifier 

[ 0 ] 


Supprimer 

□ 


Sur cette page, vous avez la possibility d’ajouter des droits pour des utili- 
sateurs qui n ont pas le role Contributeur, ou de redefinir les droits des 
roles que nous avons actives dans la configuration precedente. 

Nous avons donne ici a I’utilisateur Pierre, qui n’est pas contributeur, les 
droits de visualisation et de modification sur le contenu Bienvenue. Notez 
que l’ajout d’utilisateurs n’est pas tres ergonomique, il faut entrer les pre- 
mieres lettres du nom, puis cliquer sur Recherche avant de pouvoir l’ajouter. 
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De la meme maniere, nous aurions pu modifier les droits generaux des 
utilisateurs authentifies pour ce noeud. 

Role Voir Modifier Supprimer FigiUG 8— 75 

authenticated user 0 0 □ Definition des droits sur le contenu 

pour les utilisateurs authentifies 

00 

Comme vous le voyez, le champ d utilisation de ce nouveau modele de 
droits est assez large, mais aussi beaucoup plus complexe a gerer que 
celui « par role » de Drupal. Faites toujours tres attention et verifiez sys- 
tematiquement ce que vous faites ; veillez notamment a ne pas rendre 
public un contenu que vous cherchez a proteger. 


En resume 

• Le module Book permet de hierarchiser des contenus les uns par rap- 
port aux autres. Une hierarchie appelee Livre peut regrouper des con- 
tenus de tout type. 

• Les revisions permettent d’historier chacune des modifications 
apportees au contenu. Pensez toujours a indiquer les raisons de vos 
modifications de contenu dans le journal des revisions. 

• Le module CCK permet de creer des types de contenu complexes, 
dotes de nouveaux champs. CCK est un outil fondamental pour 
structurer les types de contenu. 

• Le module Views permet de creer des listes de contenus presentees 
sous la forme de pages. 

• II est possible d’etendre le systeme de droits sur les contenus en ajou- 
tant de nouveaux modules. Attention, ces modules sont potentielle- 
ment incompatibles les uns avec les autres. 


Modules MAGIQUES Les autres modules de droits pour les contenus 

De nombreux autres modules permettent, comme Node 
Access de definir une strategic de droits. 

Les modules Taxonomy Access Control et Taxonomy 
Access Control Light (une version plus simple du prece- 
dent) permettent tous deux de specifier des droits en 
fonction de la taxonomie portee par un contenu (ex. les 
documents avec le terme « recrutement » sont accessi- 
bles par le role XXX). 

► http://drupal.org/project/taxonomy_access 

► http://drupal.org/project/tac_lite 

Le module Simple Access permet de faire la meme chose 
que Node Access dans une version plus simplifiee. 

► h tt p ://d r u pa I . o rg/p roj ect/s i m p I e_a ccess 


Organic Group - un gros acteur dans le monde des 
modules Drupal - permet de gerer des groupes d'utilisa- 
teurs. Son modele d'acces aux contenus s'appuie lui 
aussi sur des groupes. 

► http://drupal.org/project/og 

Faites cependant attention de bien systematiquement 
tester le fonctionnement de ces modules, surtout si vous 
comptez en cumuler plusieurs. Ms ne sont pas tous com- 
patibles et il peut en resulter que des contenus soient 
visibles pour tous alors qu f ils ne le devraient pas. 
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Structurer les pages 


Nous maitrisons maintenant tous les aspects de la gestion de 
contenus ; il est done temps de s’interesser a leur presentation. 
Drupal nous permet d’envisager ce travail sous deux angles 
distincts : l’organisation des pages par zones fonctionnelles 
et le changement radical de l’apparence de ces pages a travers 
les themes. Nous aborderons le premier point dans ce chapitre, 
et traiterons le deuxieme quelques pages plus loin, au sein 
du chapitre 11, « Modifier fapparence ». 


SOMMAIRE 

► Comprendre les blocs 

► Fabriquer ses propres blocs 

► Gerer finement la visibility 
des blocs 

► Fabriquer des nouveaux menus 
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Figure 9-1 

Les grandes regions 
d'un theme Drupal 


Le modele de presentation 

La disposition des elements dans une page fabriquee par Drupal repose 
sur deux concepts : les regions et les blocs. 

• Un bloc est une zone rectangulaire contenant des informations et 
eventuellement un titre. 

• Une region est une partie de la page qui est capable de recevoir une 
liste de blocs. 

Les regions ne sont pas des zones statiques et predefinies par Drupal. 
Elies sont directement gerees par le theme que votre site utilise a un 
moment donne. Le nombre de regions, ainsi que leur emplacement, 
peut done varier d un theme a l’autre. Cependant, la majorite des themes 
pour Drupal definit au moins cinq regions de base, et le theme Garland, 
que vous utilisez sans le savoir depuis le debut de votre exploration, 
n’echappe pas a cette regie. Nous avons ainsi la barre de gauche Q, la 
barre de droite ©,r en-tete Q, le pied de page 0 et le contenu 0. 



Colchique , car chaque brin d'herbe est unique.,. 





Len-tete et la barre de droite sont ici reduits a leur plus simple 
expression : ces deux regions sont en effet vides de blocs. En revanche, 
nous avons un bloc Connexion utilisateur sur la region Barre de gauche, 
et un bloc Propulse par Drupal au niveau du pied de page. 
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La liste des blocs 


Les deux questions que Ion se pose a ce stade sont : « D’ou viennent les 
blocs ? » et « Comment en ajouter sur une page ? » Pour la premiere ques- 
tion, vous devriez maintenant avoir une petite idee de la reponse : ce sont 
bien entendu les modules qui sont a l’origine des blocs. Chaque module peut 
fournir un certain nombre de blocs, que vous pouvez ensuite positionner oil 
bon vous semble, tant qu’il s’agit d une region definie par le theme. 

Pour passer de la theorie a la pratique, dirigeons-nous vers la page de 
gestion des blocs, via Construction du site > Blocs. Sur cette page, vous 
constatez que toutes les regions que nous venons d’evoquer sont mate- 
rialisees par des zones en pointilles. 

Dans le tableau qui se trouve au centre de cette page, nous avons la liste 
des regions fournies par le theme (en gras), et en dessous de chaque 
region, la liste des blocs qui la composent actuellement. Lorsque la 
region est vide de blocs, Drupal vous previent par le message Aucun bloc 
dans cette region. 


Bloc 

Region 

Operations 

Barre de gauche 



Connexion utilisateur 

Barre de gauche C 

configurer 

Navigation 

Barre de gauche C 

configurer 


Borrc dc droitc 

Aucun hlnr Han ? s cette region 

Conte nu 

Aucun bloc dans cette region 

Entete 


Pied de page 

* 

Pmpulse parflrijpal 

Pied Hf» pagr» 

0 j 

cnnfigurRr 

Desactive 




*1* 

Commentaires re cents 

<aucun> 

- ) 

configurer 


Liens primaires 

<aucun> 

V | 

configurer 

* 

Liens secondaires 

<aucun> 

V | 

configurer 

+ 

Nouveaux membres 

<aucun> 

c I 

configurer 


Syndication 

<aucun> 

V 

configurer 

*1* 

Selecteurde langue 

<aucun> 

0 

configurer 

* 

Utilisateurs en ligne 

i <aucun> 

- 

configurer 


Figure 9-2 

Panneau de gestion des blocs 


O'! 
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Bon a savoir 

Bloc de navigation dans un livre 

Nous parlions precedemment dans cet ouvrage du 
module Book qui nous a permis de creer notre 
FAQ. Ce module fournit lui aussi un bloc extreme- 
ment pratique, nomme Book Navigation. En 
ajoutant ce bloc au sommet de la region Barre de 
droite, vous disposerez ainsi d'un systeme de 
navigation dans les livres, et done dans la FAQ, 
integree a votre site. Ce bloc est parametrable 
pour ne s'afficher que lorsque I'utilisateur est deja 
sur une page de livre ; pour ce faire, cochez 
I'option Show block only on book pages (ne 
montrez ce bloc que sur les pages de livre) et enre- 
gistrez la configuration du bloc. 


Figure 9-3 

Reorganisation des blocs 


Enfin, en bas de la liste, dans la section Desactive , se trouvent les blocs 
qui ne sont presents dans aucune region. 

Par defaut, Drupal a juste positionne, lors de son installation, trois blocs 
fondamentaux : 

• le bloc Connexion utilisateur sur la region Barre de gauche , correspon- 
dant a la boite de connexion que voient les utilisateurs anonymes et 
que nous avons maintenant l’habitude d utiliser. Nous decouvrons 
ainsi un comportement important des blocs : ils peuvent devenir 
invisibles selon le contexte de la page (par exemple, lorsque l’utilisa- 
teur est deja identifie) ; 

• le bloc Navigation , place egalement sur la region Barre de gauche et 
que nous avons deja largement utilise, puisqu il est notre menu Admi- 
nistrateur. La aussi, cela nous apprend une autre caracteristique des 
blocs : leur contenu est dynamique et peut changer en fonction du 
contexte. Dans le cas present, en fonction du role de lutilisateur con- 
nects, un menu correspondant a ses droits sera affiche ; 

• le bloc Propulse par Drupal est positionne dans la region Pied de page. 

Positionner de nouveaux blocs ou placer des blocs encore desactives dans 
une region de votre choix est une operation tres simple. II suffit d utiliser 
le systeme de glisser-deposer que nous avons deja mis en oeuvre plusieurs 
fois. Lautre maniere de faire consiste a utiliser la liste deroulante qui se 
trouve en face de chaque nom de bloc, mais force est de reconnaitre que 
cela est beaucoup moins pratique. 

Par exemple, pour respecter la presentation que nous avons definie lors 
de la conception de notre storyboard, la boite de connexion et le menu 
ne doivent pas etre a gauche, mais a droite. II suffit pour cela de faire 
glisser ces deux blocs sous la region Barre de droite. 

Bk>c Region Operations 

Barre de gauche 

Aucun bfoc dans cetle region 


Barre de droite 

4* Connexion utilisateur* 
4+ Navigation’ 


Barre de droite C configurer 


[ Barre de droite C | configurer 


Notez que vous pouvez de la meme maniere organiser les blocs les uns 
par rapport aux autres au sein d une meme region. Une fois foperation 
realisee, appuyez sur le bouton Enregistrer les blocs et retournez sur la 
page d’accueil pour juger du resultat. Vous disposez d une nouvelle 
colonne de droite et celle de gauche a disparu. 
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Lin nouvel article 

ven . C6 05:2009 - 1 6:20 — Marina 
Corpsde I'arllcJe... 

Ajn i iter un rr>rn rnsn tains 


admirsi strata ur 

Mon compte 
CrEer uncontenu 
Admin i slier 
Sedeconnecter 


Recrutement d'un equipe Exploitation pour une grande banque Allemande 

Tier. 0GQ3 : £0CS - 1 1:4£ — odmin'Etrnbeur 

Prest»tian Rfin lisfift' 

La mi 33 ion a con siatc c n I a constitution on un temps record d'unoquipe dcdiccs a I 'exp location du syntonic informatiquc d\mc grande banque 
□llemande. 


Bienvenue 

mar 0&02 20® - 23:38 — Marino 

Bienvenue surle site de Cole hkiue Cortseil. 

le csbinetde conseil en nessounces humaine qui a I’sth/qu^ a coeur . 

Ensavoirplus 2 fichiers attaches Recrutement 


Q0 

0 Colchique Conteil - Toutdraitr recervsr - Contscfcez-nouE- Ce cite oe! pro puke par Crop all. 

Figure 9-4 Deplacement des blocs vers la droite 


Les blocs personnalises 

Creation d’un bloc personnalise 

Un bloc est generalement fabrique par un module. Les blocs disponibles 
en standard sont done issus des modules installes dans Drupal par 
defaut. Pour ajouter de nouveaux blocs, il nous faut soit puiser dans ceux 
qui existent deja mais qui sont encore desactives, soit installer des 
modules supplementaires qui nous fourniront de nouveaux blocs, soit au 
final rediger un module qui fabriquera le ou les blocs repondant a nos 
besoins specifiques. 
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Cette approche modulaire des blocs serait penalisante s’il n’existait pas, 
comme pour les types de contenu, de moyen de creer a la main des blocs 
simples. De tels blocs correspondent generalement a un texte statique que 
Ion cherche a inserer dans Tune des regions du theme. II peut s’agir dans 
notre exemple de la ligne d ’informations legales que nous avons definie sur 
notre storyboard et que nous placerons dans la region Pied de page. 


Figure 9-5 

Ce que nous cherchons a obtenir 
pour le pied de page 



Actils a la page « inform ation 
ligales * 



anformations legales... 


Bonnes pratiques 

Sachez decrire ce que vous faites 

De maniere generate - et ceci vaut pour toutes les 
descriptions de bloc, de type de contenu ou de 
vue soyez intransigeant quant a la qualite des 
descriptions que vous donnez, meme - et surtout 
- si elles ne sont pas destinees a etre affichees sur 
le site. Lorsque vous aurez une vingtaine de types 
de contenu, une centaine de vues et beaucoup 
plus encore de blocs, vous vous feliciterez d'avoir 
pris cette bonne habitude. 


Pour fabriquer ce bloc, nous devons retourner sur la page de gestion des 
blocs et cliquer sur l’onglet Ajouter un bloc. Le formulaire qui apparait 
commence par la Description du bloc qui sera affichee sur la page de ges- 
tion. Donnez ici une description suffisamment explicite pour reperer 
votre bloc facilement dans la liste, qui sera a terme tres volumineuse. 

Nous avons ensuite le Titre du bloc qui est optionnel, et encore plus lorsqu’il 
s’agit d’un bloc destine au pied de page ou a l’en-tete. Nous le laisserons 
done vide pour rediger le Corps du bloc , qui nous interesse davantage 
puisqu’il contiendra les informations legales concernant notre site. 

Comme les contenus, les blocs disposent de formats d’entree que vous 
pouvez selectionner dans la section Formats d'entree presente sous le 
champ Corps du bloc. Pour ne pas etre embete avec un eventuel filtrage 
du code HTML, nous choisissons ici Full FITML. Comme nous avons 
dans le precedent chapitre active TinyMCE pour ce format d’entree, 
nous beneficions par consequent de l’editeur visuel. 


Figure 9-6 

Creation d'un bloc personnalise 
pour le pied de page 


Description du bloc : 

| Pied de page du site | 

Une courts desorption de votre bloc. Utileee sur le. vue d'e nsemble des bbes. 

litre du bloc : 

I I 

Le titre du bbc tel qu'il est effbhe a rutilisateur 

Corps du bloc : 

B I U ABC | ^ ^ ^ | Styles - Format T |= |= | ~=W tW \ 

| & 3t ® HTmL — ‘ I | n 

©Calchique Co ns eil - Tout droits reserves - Ce site est p repulse par Drupal . 


Ceci fait, laissons pour l’instant telles quelles les options de parametrage 
qui suivent et cliquons sur Enregistrer le bloc. De retour sur la page de 
configuration des blocs, vous devez voir apparaitre dans la section Desac - 
tive la description du nouveau bloc. 
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4* Pied de page du site 


<aucun> 


Figure 9-7 

configurer supprimer 

Notre bloc est maintenant dispomble dans la liste 


Comme pour n importe quel autre bloc, vous pouvez le deplacer dans la 
region de votre choix, ici Pied de page. Vous disposez a present de deux 
blocs dans cette region, dont celui nomme Propulse par Drupal. Ce der- 
nier etant quelque peu redondant, deplacez-le dans la section Desactive , 
puis enregistrez les blocs. 


Pied de page 


Pied de page du site’ Pied de page C | configurer supprimer 


Desactive Figure 9-8 

* Propuise par Drupai* \ <ajcun > cj configurer Deplacement du bloc dans la region Pied de page 


Ceci fait, vous pouvez constater que notre nouveau bloc est bien visible 
en bas de la page. 

Suppression d’un bloc personnalise 

Bien entendu, si un bloc personnalise peut etre cree, il peut aussi etre 
supprime. En tant qu’administrateur, il nous faut retourner dans l’admi- 
nistration des blocs. Sur la ligne de chaque bloc que nous avons cree, 
nous constatons la presence d un lien supprimer. C’est ce lien qui nous 
permettra, apres confirmation, de faire disparaitre un bloc. De meme, le 
lien configurer permet de retourner sur la page de parametrage du bloc 
pour en modifier les reglages. 


Modules magiques Des blocs en onglets 

II existe un excellent module appele Quick Tabs qui 
permet de cumuler plusieurs blocs en un seul sous 
la forme d'onglets. II peut fonctionner aussi bien 
en mode Ajax (les blocs sont ainsi charges de 
maniere asynchrone) ou non-Ajax (les blocs sont 
tous charges, puis leur visibility successive assuree 
par JavaScript). 

► http://drupal.org/project/quicktabs 


Gerer la visibility des blocs 


Des blocs visibles en fonction du chemin 

Le second bloc que nous allons creer est celui de presentation de la 
societe, qui devra etre affiche sur le cote droit de la page. 




Presentation ^ 
courte de la 
societe 

Sur ia page d'accueil 




Figure 9-9 

Ce que nous cherchons a obtenir sur le cote droit 
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A la difference du bloc precedent, il ne devra s'afficher que sur la page 
d'accueil et uniquement pour les utilisateurs anonymes. Comme prece- 
demment, nous allons cliquer sur Ajouter un bloc et renseigner les infor- 
mations de contenu. S'agissant d un bloc a afficher sur le cote, nous 
allons le do ter cette fois dun titre. 


Figure 9-10 

Creation du bloc personnalise 
de presentation de la societe 


Description du bloc : 

| Description de la societe 

Une courts desorption de votre bbc. Utilsbe sur la wue d'ensemble des bloca. 

Titre du bloc : 

|Gui sornmes-nous ? 

Le title du bloc tel qu'il eet affiche a [utilmteur 

Corps du bloc : 

B I U MG ^ ^ ^ ! Styles * Paragraphe + E |E • ^ tW \ 

& J #) Him. — Q_ Q | x, x 1 | H 

Colchtque est une societe de canseil en management specialise dans les ressources humaines dans le 
domaine des technologies de I' information... 


Cette fois, nous allons regarder de plus pres les options de notre bloc en 
commen^ant par la section Parametres de visibility specifiques a I'utilisateur. 


Figure 9-11 

Specification des parametres de visibility 
specifiques a I'utilisateur 


V P arametne s de vi s i b i I ite s pec if iq Lie s a I 'uti I i s ate li r 

Pom metres de visibilite persoimnlises : 

Les utilisateurs ne peuvent pas contra ler s'ils veulent afficherce bloc oli non. 

' Affiche rce bloc pardefaut mais auto riser I'utilisateur a le masquer, 

Masquer ce bloc pardefaut. mais auto riser I'utilisateur a I 'afficher. 

Permettre aux utilisate u rs de peiEonnaliser b viabilite de ce bloc dans les parametres de leurcompte. 


Ici, il nous est possible d'offrir aux utilisateurs disposant d un compte sur 
le site (par exemple, les contributeurs) la possibility de decider s'ils veulent 
que le bloc soit visible ou pas. Si vous rendez ce choix possible, I'utilisateur 
disposera sur sa page M on compte , d'une serie de cases a cocher lui per- 
mettant de regler la visibilite de chacun des blocs configure dans ce sens. 
Ces reglages lui sont specifiques et n'influencent pas l'affichage defini en 
standard pour l'ensemble des utilisateurs ou visiteurs anonymes. 

Par defaut, rien n'est selectionne et cela signifie que le bloc sera affiche 
dans tous les cas ; cette option convient tres bien a notre bloc Ma societe. 
Nous aurions cependant pu selectionner l'une des options suivantes : 

• Les utilisateurs ne peuvent pas controler s'ils veulent afficher ce bloc ou non ; 

• Afficher ce bloc par defaut mais autoriser I'utilisateur a le masquer ; 

• Masquer ce bloc par defaut, mais autoriser I'utilisateur a /'afficher. 
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La section suivante, Parametres de visibilite specifiques aux roles , permet 
d’afficher ou de cacher le bloc en fonction du role de lutilisateur con- 
nect^. Dans notre cas, ce bloc ne doit etre affiche que pour lutilisateur 
anonyme, nous cochons done anonymous user. 

Parametnes de visibilite specifiques au roles 

Affiche i le bloc pour des roles specifiques : 

0 anonymous user 

□ authenticated user Figure 9-12 

Definition des parametres de visibilite par roles 

LJ contributeur 

Le dernier parametrage possible, Parametres de visibilite specifiques a la 
page , est de loin le plus interessant. II nous permet de conditionner l’affi- 
chage du bloc en fonction du chemin interne de la page en cours. Cette 
section propose trois choix, suivis dune zone de texte permettant de 
definir la condition d’affichage. 

• Afficher le bloc sur toutes les pages exceptees celles listees : lorsque cette 
option est utilisee, la zone contient une liste de chemins (un par 
ligne) pour lesquels le bloc ne sera pas affiche. Le format des chemins 
est explicite un peu plus loin (paragraphe suivant). 

• Afficher le bloc seulement sur les pages listees : inversement, le bloc ne 
sera visible que pour les chemins indiques dans la zone. 

• Afficher si le code PHP suivant retourne TRUE : il s’agit d une option a 
manier avec beaucoup de precautions, qui permet de saisir dans la 
zone une fonction PHP qui devra renvoyer TRUE pour que le bloc soit 
visible, ou FALSE pour qu’il soit invisible. Un exemple illustrera ce 
choix un peu plus loin (pages suivantes). 

Pour les deux premiers choix, chaque chemin de la liste peut utiliser fun 
des formats suivants : 

• un chemin simple, par exemple node/1 pour http://mon_site/node/1 . II 
peut s’agir ici autant d un chemin interne que d un alias ; 

• un chemin utilisant le caractere * qui va correspondre a nimporte 
quelle chaine de caracteres. Par exemple, node/* rendra le bloc visible 
pour les chemins internes node/1, mais aussi node/2, node/12, 
node/l/edit, et ainsi de suite. Ici aussi les alias sont autorises ; 

• un chemin utilisant plusieurs caracteres * sur une meme ligne. Par 
exemple node/*/* fonctionnera aussi bien pour le chemin node/1/ 
edi t que pour node/l/pri nt. Mais il ne fonctionnera pas pour node/1 
tout court car il n’y a qu un seul niveau et notre motif en demande 
deux. Encore une fois, les alias peuvent etre de la partie ; 
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• un chemin predefini : lorsqu’on desire rendre un bloc visible a la 
racine, il n est en effet plus possible d’utiliser la syntaxe precedente (le 
chemin serait vide car l’adresse complete serait http://mon_site/). La 
solution est alors d utiliser le chemin predefini <f ront> qui permettra 
d’afficher le bloc lorsque futilisateur est sur la page d’accueil. 

Grace a ce systeme, il est done possible de positionner des blocs dans 
n importe quelle region, et d’afficher des blocs differents dune section a 
l’autre de votre site. Dans notre cas, nous n’allons afficher ce bloc Ma 
societe que pour la page d’accueil. Nous cochons done le second choix et 
utilisons le chemin predefini <f ront>. 


Figure 9-13 

Le bloc Ma societe ne sera affiche 
que sur la page d'accueil 


Afficher le bloc sur certaines pages seulemer 

O Afficher le bloc surtoutes les pages eacepte 
Afficher le bloc seule merit sur les pages list) 
O Afficher si le code PHP suivant retourne TRl 

Pages : 

<fnont> 


Ceci fait, enregistrez votre bloc et deplacez ce nouveau bloc dans la 
region Barre de droite, juste au-dessus du bloc Connexion utilisateur et 
enregistrez. 


Figure 9-14 

Positionnement de notre bloc 
sur la region Barre de droite 


Barre de droite 

4* Description de la societe 

4* Connexion utilisateur 


Allons a present sur la page d’accueil pour verifier que notre bloc n’appa- 
rait effectivement pas en haut a gauche (car nous sommes encore con- 
nects en tant qu’administrateur). Une fois ce point valide, deconnectez- 
vous et le bloc devrait apparaitre. 


Figure 9-15 

Notre bloc personnalise en situation 


Qui sommes -nous ? 

Cotchiquee st une societe de 
conseil en management specialise 
dans les ressources humaines 
dans le domaine des technologies 
de I'information... 


Cliquons ensuite sur notre premier contenu pour quitter la page 
d’accueil, et constater de ce fait la disparition du bloc. Tout s’est bien 
passe ? Parfait ! 
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Des blocs visibles par PHP 

A present, pour illustrer le troisieme choix de visibilite - le mode PHP 
nous allons creer a titre d exemple un bloc divertissement pour fadminis- 
trateur. Ce bloc sera affiche sur toutes les pages dans l’en-tete du site, pour 
vous rappeler que vous etes connecte en tant qu administrateur sur le site, 
et quil faut done preter attention a chacune de vos actions. 

Commen^ons par creer un nouveau bloc comme ceci : 


Description du bloc : 

[Avertisse merit 

Une courts desorption de votre bloc. Utilises sur la. vue d'ensemble des blocs. 

Titre du bloc : 


T Faragraphe \ — I— | i 

Figure 9-16 

Creation du bloc personnalise divertissement 

Cette fois, dans la section Parametres de visibilite specifiques a la page , 
nous allons selectionner le troisieme choix et saisir le code suivant : 


Ls titre du bbc tel qu'il est affiche a rutilEaleur 

Corps du bloc : 

b i u &s£ m m m . styles 

x, x 2 | 

Attention !!! ^ous etes ADMINISTRATEUR 


Afficher le bloc sur certaines pages seulement : 

' - ’ Afficher le bloc sur toutes les pages exceptees celles listees. 

■ . ’ Afficher le bloc seulement sur les pages listees. 

V Afficher si le code PHP suivant retourne TRUE (mode PHP. experts seulement). 

Pages : 

global $user; 

return $user->uid==1 ; Figure 9-17 

Saisie de la condition PHP d'affichage du bloc 


Le code PHP de la zone doit etre encadre par les balises <?php et ?> pour 
etre interprets par Drupal comme une fonction pouvant renvoyer TRUE 
(vrai), pour obtenir Taffichage du bloc, ou FALSE (faux) lorsquil doit 
rester cache. 

Le code de notre fonction s’appuie sur le fonctionnement interne de 
Drupal et permet de savoir si lutilisateur qui visualise la page en cours 
est effectivement fadministrateur ou non. Lobjet global $user contient 
toutes les informations sur cet utilisateur. Sachant que fadministrateur 
est le premier utilisateur cree lors de finstallation de Drupal, il a syste- 
matiquement 1 comme ID. C’est ici le sens de notre test. 
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Vous pouvez maintenant enregistrer le bloc et le deplacer vers la region 
En-tete. Une fois la configuration des blocs enregistree, vous devriez 
voir apparaitre ravertissement. S'il n est pas assez visible, vous pouvez 
editer a nouveau le bloc et, en desactivant TinyMCE, ajouter une belle 
couleur rouge a la main dans le code XHTML. 


Figure 9-18 

Le message divertissement en situation 


Attention HI Vous etes ADMIN IS TRATEUR 


Colchique Car chaque brin d 


Accueil ► Admin is trer • Construction du site Blocs 


Modules magiques 

Blocs a visibility programmee 

Lorsqu'un site contient des centaines de blocs, il 
peut devenir penible de gerer leur visibility a la 
main alors qu'il serait si simple de decrire cette 
visibility en code PHP. 

C'est le role du module Block Visibility Page, qui 
fournit un service interne pour decrire en mode 
programme la visibility de chaque bloc. L'autre 
avantage de cette approche est qu'il suffit de 
copier le code en production sans avoir a parame- 
ter a nouveau la visibility des blocs. 

► http://drupal.org/project/bpv 


A present, deconnectez-vous pour verifier que le bloc a bien disparu, et 
reconnectez-vous en tant que Marine pour valider le fait qu'il ne s'affiche 
toujours pas. 

La possibilite qu'offre Drupal de saisir ici du code PHP s'accompagne 
des memes preconisations que pour le format d'entree PHP code. Ne 
mettez jamais de code long dans cette zone, juste une condition simple 
avec une reference a une variable ou un appel de fonction. Si vous avez 
besoin de plus, utilisez une fonction que vous placerez dans un module 
(voir le chapitre 14, « Ecrire son premier module »). 

Visibility des blocs de modules 

Nous avons vu comment creer un bloc et gerer sa visibilite. II convient de 
noter egalement que cette possibilite n est pas reservee qu' aux seuls blocs 
personnalises mais quelle peut etre etendue a l'ensemble des blocs pro- 
venant de tout module. 

Tres souvent, les blocs issus des modules integrent leur propre logique 
d'affichage. Le bloc Connexion utilisateur, par exemple, est cache des 
que lutilisateur est identifie. Pourtant, si nous allons sur le lien configurer 
de ce bloc, aucune information de role n’a ete renseignee. C'est le 
module lui-meme qui prend en charge ce comportement. 

Cependant, il est possible de definir (ou eventuellement de forcer), a tra- 
vers la configuration d'un bloc de module, les parametres de visibilite. 
Pour prendre un exemple, interessons-nous au bloc Commentaires 
recents, dont l'intitule est suffisamment explicite. Ajoutez ce bloc a la 
region Barre de droite et enregistrez. Ou que vous alliez sur le site, ce 
bloc restera visible, et ce, quel que soit votre role. 

A present, retournons dans l'administration des blocs pour cliquer sur 
son lien configurer et changer sa visibilite afin qu'il ne soit present que sur 
la page d'accueil (avec l'adresse <f ront> comme pour le bloc Ma societe). 
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Enregistrez et jugez du resultat. La visibilite est maintenant specifique et 
restreinte a la page d’accueil. Nous avons ainsi la possibility de redefinir 
la visibilite de l’ensemble des blocs, et pas seulement de ceux que nous 
avons nous-meme crees. 


Commentates recents 

Merci a vous, je vais encore 
il y a2 jours 19 heunes 

Article passionnant mais Figure 9-19 

ii y a 2 jours 19 heures |_ e bloc des commentaires recents 


De maniere plus anecdotique mais neanmoins tres utile, il est aussi pos- 
sible de changer le titre d un bloc de module. Si « Commentaires 
recents » vous semble trop banal, vous pouvez y remedier en configurant 
le module et en ajoutant votre touche personnelle. 


Titre du bloc : 

[Ce qui sfestdit,,, 

Modifiez le title pardefautdu bloc. Indiquez (<nc 


Figure 9-20 

Definition d'un titre personnalise pour un bloc standard 


Ainsi, apres enregistrement, le bloc aura un nouveau titre plus original et 
personnalise que le simple « Commentaires recents ». 


Ce qui s'est dit... 

Merci a vous, je vais encore 
il y a 2 jours 19 heures 
Article passionnant mais 
il y a2 jours 19 heures 


Figure 9-21 

Affichage des commentaires recents 
avec notre titre personnalise 


Vous pourriez de la meme maniere forcer le titre dynamique du bloc 
Navigation pour inscrire le texte de votre choix, ou rendre sa visibilite 
contextuelle, mais ce nest pas forcement la meilleure des idees... En 
vidant la valeur du titre, vous retrouverez le titre par defaut tel que l’a 
defini le module. 

Vous l’aurez compris, le maitre mot qui guide le fonctionnement de 
Drupal est controle. Tout est modifiable, parametrable et adaptable a vos 
besoins, mais ce n est pas toujours aussi simple et direct. Lorsque vous 
n arrivez pas a obtenir l’effet desire, n hesitez jamais a demander de l’aide 
sur les forums (http://drupalfr.org/forum). 
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Structure des menus 

Dans le vaste panel des blocs disponibles figure une categorie de blocs 
qui se revelera particulierement utile : les blocs de type menu. Depuis le 
debut de notre exploration, nous utilisons sans le savoir lun d’entre eux : 
le bloc Navigation, qui controle toutes les actions au sein de Drupal. 

A finstar de la taxonomie, les menus sous Drupal fonctionnent suivant 
une logique d’arborescence : nous distinguons ainsi de grands ensembles 
appeles menus qui contiennent des arborescences de liens appeles ele- 
ments de menu. 

Pour mieux visualiser ce concept, dirigeons-nous vers Construction du site 
puis Menus pour voir apparaitre les trois menus standards de Drupal : 

• le menu Navigation que nous avons utilise intensivement - tous les 
elements de ce menu correspondent a des actions liees aux fonction- 
nalites des modules actives ; 

• le menu Liens primaires qui par defaut est vide, et qui correspond 
generalement aux liens que Ton trouve en haut de la page ( contact , se 
deconnecter , etc.) ; 

• le menu Liens secondaires qui, lui aussi, est vide par defaut et contient 
generalement les acces aux grandes sections du site. 

Cliquez maintenant sur le menu Liens primaires , pour constater que 
Drupal affiche bien un menu vide d’elements. 

Revenez en arriere et faites de meme avec Liens secondaires ; vous 
obtenez le meme resultat. Enfin, cliquez sur Navigation , et cette fois-ci 
Drupal devient beaucoup plus loquace : 



Element de menu 

Active Deplie 

Operations 

Astuces de composition (desactive) 

Mon compte 

0 

□ 

modifier 

modifier 


Creer un contenu 

0 

□ 

modifier 


+$► Article 

0 

□ 

modifier 


Page 

0 

□ 

modifier 

Figure 9-22 

Administrer 

0 

□ 

modifier 

Le contenu du menu Navigation 

Construction du site 

0 

□ 

modifier 


Nous y retrouvons toutes les actions 

que 

nous avons 


chacune fournie par un module. Un point interessant a noter ici est le 
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fait que toutes les entrees de menu sont affichees sans preoccupation de 
permissions. En effet, la visibility dun element de menu fait partie inte- 
grante de la gestion assuree par Drupal. Nous pouvons done aj outer 
n importe quel element a un menu, il ne sera affiche que si futilisateur a 
la permission de lancer faction correspondante. 

Gestion des chemins 

Pour mieux saisir la logique de fonctionnement des menus, interessons- 
nous au menu Liens primaires et definissons les elements qui le compo- 
sent, en nous appuyant sur ce qui a ete decide dans notre storyboard, 
e’est-a-dire en implementant le lien se deconnecter. 


Formulaire de 


contact 

~ 


Affichersi I'utilisateur est 
authentifie 




Nous contacter Se deconnecter 


Figure 9-23 

Ce que nous devons obtenir pour le menu primaire 


O'! 


Pour ce faire, retournez sur la liste des menus, et cliquez sur Liens pri- 
mages puis sur Ajouter un element. Commenc^ons par renseigner refor- 
mation fondamentale : le chemin interne du menu. Nous avons deja 
aborde cette notion de chemin interne dans le chapitre consacre aux 
contenus. S’agissant des menus, la nouvelle notion importante a retenir 
est le fait que leur gestion dans Drupal est totalement deterministe. II en 
decoule f obligation pour chaque module de declarer prealablement au 
systeme coeur de Drupal la liste exacte et exhaustive des chemins 
internes qu’il prend en charge. 

Si on examine fexemple du module User qui effectue toute la gestion 
des utilisateurs, nous remarquons qu il declare (entre autres) deux che- 
mins correspondant a deux actions fondamentales : 

• user/login, qui va afficher le formulaire de connexion de futilisateur ; 

• 1 ogout, qui va deconnecter futilisateur courant. 

Faites-en f experience tres simplement en saisissant dans la barre 
d’adresse de votre navigateur http://www.colchique-conseil.fr/logout. Vous etes 
alors automatiquement deconnecte. A present, si vous entrez fadresse 
http://www.colchique-conseil.fr/user/login, le module User interceptera fappel a 
ce chemin et affichera le formulaire de connexion. Vous pourrez ainsi 
vous reconnecter en tant qu administrateur. 

Certains modules declarent des chemins plus complexes que ces simples 
actions. Par exemple, le module Node, qui gere toute la logique des con- 
tenus, declare a Drupal prendre en charge le chemin node/*, signifiant 
« tous les chemins comme^ant par node/ ». C’est done ce module qui 
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prendra en charge l’affichage des contenus lorsque vous saisissez une 
adresse de la forme www.colchique-conseul.fr/node/1 . 

Le systeme de menus de Drupal repose done sur ce principe et vous oblige 
a saisir un chemin interne (ou un alias) qui soit valide, e’est-a-dire qui cor- 
responde a un chemin pris en charge par un module installe. Par conse- 
quent, si vous saisissez le chemin mauvai s_chemi n, Drupal detectera le fait 
qu aucun module ne le gere et vous affichera un message d’erreur. 

Les seules exceptions a cette regie sont bien evidemment les chemins 
dits externes , e’est-a-dire pointant sur d’autres sites web. De tels chemins 
doivent alors etre ecrits sous une forme absolue, e’est-a-dire toujours 
precede de http://, par exemple http://drupal.org. 

Creation d’un element de menu 

Passons a la pratique, et ajoutons le menu de deconnexion en saisissant 
les informations suivantes. 


Figure 9-24 

Definition d'un nouveau menu 
« Deconnectez-vous » 


Chemin : + 

[logout | 

Le chemin de Drupal vans lequel pointe cet Element de menu. Cefe peut etre un chemin interne a, 
Entrez <front> po u r po inte r ve re b page d'accueil. 

Title dn lien dans le menu : 

[ Deco n nectez- vo u s 

Texts correspond au nomdu lien qui sera affiche dans le menu. 

Description : 

Cliquez ici pour vous deconnecter 

La desorption affichee quand le po inte u r su rvo le cet e le me n t de menu. 


• Le Chemin que nous utilisons ici est celui fourni par le module User 
que nous venons d’analyser. 

• Le litre du lien dans le menu correspond au libelle de notre element de 
menu. Attention, le code XHTML n est pas autorise. 

• La Description est, quant a elle, utilisee comme bulle d’aide sur le lien, 
il est done important de la renseigner. 

• Le parametre suivant correspond au fait que felement de menu est 
active ou non. Nous le laissons logiquement a Active. 

Les trois parametres restants n ont pour le moment pas d’importance, 
nous y reviendrons un peu plus loin. Vous pouvez des lors enregistrer 
votre element de menu, action qui renvoie a la liste des elements du 
menu Liens primaires. 


Figure 9-25 

Le menu est maintenant enregistre. 


Element de menu Active Deplie Ope ml ions 

^ Deconnectez-vous 0 EH modifier sup primer 
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Notre nouvel element est en place et vous pouvez comme toujours le 
modifier ou le supprimer. Mais la chose interessante a noter se passe en 
haut a droite de l’ecran, avec rapparition de notre menu primaire. 

Figure 9-26 

Voila notre premier menu en place. 


Vous pouvez cliquer sur ce lien ( Deconnectez-vous ) pour constater quil 
est parfaitement operationnel, mais surtout qu’une fois Tutilisateur 
deconnecte, il disparait. Comme nous l’avons mentionne plus haut, un 
element de menu est soumis au systeme de permissions de Drupal. 
Ainsi, tous les liens qui n ont pas de sens pour lutilisateur disparaissent, 
comme ici une deconnexion pour un visiteur anonyme. 

De la meme maniere, nous pouvons renseigner des sections de notre site 
cette fois-ci dans le menu Liens secondaires. Dans notre storyboard, nous 
avions prevu trois sections : Nos publications , Les Billets et FAQ. 


Figure 9-27 

Ce que nous desirons obtenir pour les liens secondaires 


Nous disposons, grace au module Views etudie precedemment, des deux 
listes pour les types de contenu Article et Billet. II nous est done possible 
d’ajouter ces deux sections aux liens secondaires. 

Le processus est exactement le meme que pour l’ajout d un element dans 
le menu Liens primaires , commen^ant par la selection du menu Liens 
secondaires > Ajouter un element. 

Le chemin que nous devons indiquer est celui que nous avons specifie 
pour Taffichage Page de la vue 1 i ste_des_publ i cations, a savoir 
publ i cati ons. 



Nos publications 

Les Billets 

FAQ 




X 

Nouvel le 

Les rubnques 
du site 

n 

Rubrique active 




Chemin : * 

[publications ] 

Le chemin de Drupal vers lequel pointe cet element de menu. Cela peut etie un chemin interne 
a Dmpal comme node/add o u une u rl exte me comme http.V/drupat. org. E ntiez <front> pour 
pointerveia la page d'accueil. 

Titre du lien dans le menu : * 

[Les Publications ] 

Texte correspond au nomdu lien q u i se la aff iche dans le menu. 


Figure 9-28 

Creation de I'element de menu pour la rubrique Nos publications 
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Vous trouverez dans cette section la lisle de nos dernieres publications 


La desorption affichee quand le po inte u r au rvo le cet element de menu. 
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Enregistrez et faites de meme avec la vue Billets. 

Enfin, nous allons ajouter notre derniere section FAQ^en utilisant cette 
fois-ci rURL associee au chemin du livre FAQ^cree precedemment. 
Lorsque les trois elements de menu sont enregistres, nous pouvons en 
modifier lordre pour correspondre a ce qui a ete defini dans le storyboard. 


Figure 9-29 

Toutes nos sections sont en place. 


Element de menu 

Active 

Deplie 

Operations 


♦f* Nos Publications' 

0 

□ 

modifier 

supprimer 

Les Billets' 

0 

□ 

modifier 

supprimer 

FAQ 

0 

□ 

modifier 

supprimer 


II ne reste alors plus qua enregistrer la configuration pour juger du 
resultat en haut a droite de la page. 


Figure 9-30 

Voila nos sections maintenant visibles. 

Comme vous le constatez, il est facile d’aj outer de nouveaux elements a ces 
deux menus tres speciaux que sont les liens primaires et secondaires. Voyons 
a present comment ajouter un bloc de menu similaire au menu Navigation. 

Ajouter un bloc de menu 

Les trois menus dont nous disposons pour finstant ne sont que des ele- 
ments parametres en standard ; il est bien evidemment possible d’en 
ajouter autant que necessaire. 

Dans notre storyboard, nous avons prevu sur la barre de droite un menu 
permettant un acces rapide aux differentes sections de la presentation de 
notre societe. 


Figure 9-31 

Ce que nous desirons obtenir 
pour les informations sur la societe 



Contactez nous Deconnectez-vous 


Nos Publications Les Billets FAQ 


La premiere etape consiste cette fois a creer un nouveau menu. Pour 
cela, retournez dans fadministration des menus et cliquez sur le lien 
Ajouter un menu. 
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Comme pour le type de contenu ou le vocabulaire, nous allons definir ici 
le Nom du menu , qui ne doit contenir que des lettres en minuscule, des 
nombres et des tirets, et bien sur etre unique. Ensuite viennent le Titre et 
la Description de votre choix. 


Nom du menu : * 

[societe 

Le nom machine de ce menu. Ce te 
des nombies, des tiiets, et dort etre 

Titre : * 

[l_a societe 

Description : 

Menu de la societe 


Figure 9-32 

Creation cTun nouveau menu La societe 


II suffit de cliquer sur Enregistrer pour que le nouveau menu devienne 
actif. Vous etes alors redirige sur la page indiquant qu’il n’y a aucune 
entree dans le menu, ce qui est assez logique. 

Arrive maintenant le moment d’aj outer nos elements de menu. Nous pour- 
rions creer les pages, et ensuite ajouter chacune d’elles en tant qu element de 
menu comme nous l’avons fait precedemment, en utilisant le chemin 
interne du contenu correspondant (node/xxx). Cependant, ce nest pas - et 
de loin - la methode la plus efficace. Cela vous obligerait a afficher a chaque 
fois le contenu dans un onglet avant de recopier son chemin interne dans la 
zone Chemin, ce qui est pour le moins fastidieux. 

Une bien meilleure option consiste a laisser Drupal faire cela tout seul. 

En effet, jusqu’a present, nous utilisions le role Contributeur pour creer 
nos contenus, donnant lieu a un formulaire de creation limitee par les 
permissions de ce dernier. Pour creer des contenus de type Page, nous 
allons utiliser le role Administrateur pour la simple et bonne raison que 
c’est le seul qui dispose de ce droit. L’administrateur n’ayant aucune 
limitation, il aura ainsi acces a un formulaire de creation beaucoup plus 
complet, comportant notamment une section bien pratique qui permet 
de definir directement un menu en meme temps que la page elle-meme. 

Voyons cela de plus pres en comme^ant par la creation de la page La 
societe. Allez en tant qu administrateur dans Creer un contenu, puis Page. 

Le debut du formulaire est familier et nous pouvons deja saisir le Titre de 
la page. La nouveaute se trouve en dessous du titre sous la forme d une 
section a deplier, Parametres du menu. 

Nous pouvons ici definir directement un element de menu en commen- 
£ant par son titre (le libelle), suivi d une zone deroulante tres importante 
qui permet de choisir oil le menu sera insere. Dans cette liste, vous 
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Figure 9-33 

Ajout de la page Qui sommes-nous ? 
en creant I'element de menu dans la foulee. 


Figure 9-34 

Le chemin interne du noeud 
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retrouvez bien sur tous les menus existants, y compris le menu La societe 
que nous venons de creer, mais egalement tous les sous-elements de 
chacun des menus. II est ainsi possible de rattacher notre nouvel element 
de menu a n importe quel menu ou element de menu existant. 

THra : 

[Qui sommes-nous ? 

Para metres du menu 


Ll Supprime cette entree de menu. 

litre dri lien darts le menu : 

|Oui sommes-nous ? 

Ce texts correspond au nom du lien qui sera affiche dans le menu. Labsezvide sivous ne voulez pas creer 
de len dans le menu 

Element parent : 

| <La societies Cj 

La proto ndeur maximal? d'un ebmeni et de bus ses enfanls est fixes a 9 . Certains Irens dans les menus 
ne po u no n L pas e tie utilises com me pa rants si leur selection les lait exceder cette limits. 

Poids : 



Facultatif. Dans le menu, les e le me n ts au poids plus sieve ee ro n t positio n n£s ve rs le bas et les e le me nts a u 
poids plus Table se rant position nes plus haul. 


Corps : 

B S U W- ® ^ i Styles 


^ Format j = |= 

HTmt -zH| Xl x 1 1 n 


Calchique est une societe de conseil en management specialise dans les ressources humaines dans le 
domaine des technologies de I' information... 


Pour l’heure, nous rattacherons le menu de notre page a <La societe>. 
Laissez le champ Poids tel qu’il est. II permet d’ordonner les elements 
dun meme niveau les uns par rapport aux autres, mais nous verrons un 
peu plus loin une technique plus efficace pour realiser la meme tache. 

Une fois le menu defini, saisissez le Corps de la page et enregistrez. Ceci 
fait, retournez dans Tadministration des menus et cliquez sur La societe. 

Nous decouvrons alors que Drupal a bien cree un nouvel element de 
menu actif. Cliquez sur modifier pour en decouvrir le contenu. Outre les 
informations deja saisies plus haut, nous voyons ici que Drupal a bien 
attribue a ce menu le chemin interne de notre noeud. 


Clio min : 

[ node/ 5 
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Renouvelez loperation pour les pages Historique, Chiffres et dates, Lequipe 
et Nos valeurs, en rattachant a chaque fois la page au menu <La societe > sans 
vous preoccuper ni de 1’ordre, ni des niveaux dans l’arborescence. 

Ceci fait, retournez dans la liste des elements du menu La societe pour 
juger du resultat : 


Element de menu 

Active 

Deplie 

Operations 


* 

Qui sommes-nous ? 

0 

□ 

modifier 

supprimer 

4 * 

Les chiffres et dates 

0 

□ 

modifier 

supprimer 

4 * 

Historique 

m 

□ 

modifier 

supprimer 

4 * 

Nos valeurs 

m 

□ 

modifier 

supprimer 

4 * 

L'equipe 

0 

□ 

modifier 

supprimer 


Figure 9-35 

Notre menu manque encore ^organisation. 


Notre menu est complet mais l’ordre des elements n est pas ideal. Arran- 
geons cela en utilisant les petites croix sur la gauche et en faisant du 
glisser-deposer pour ordonner les entrees de menu (en glissant une ligne 
verticalement), mais aussi pour modifier la hierarchie (en glissant hori- 
zontalement). 

Une fois fordre correctement etabli, il ne nous reste qua cocher la case 
Deplie de felement de menu Qui sommes-nous ?. Sans cela, ce menu ne 
serait en effet pas ouvert a l’affichage et demanderait a l’utilisateur de 
cliquer a chaque fois sur son lien pour afficher ses sous-elements. Vous 
pouvez maintenant Enregistrer la configuration. 


Element de menu 

Active 

Deplie 

Operations 


4* Qui 

sommes-nous 7 

0 

no 

modifier 

supprimer 

4* 

Nos valeurs 

0 

□ 

modifier 

supprimer 

4* 

Llequipe 

0 

□ 

modifier 

supprimer 

4* 

Historique 

0 

□ 

modifier 

supprimer 

4* 

Les chiffres clef 

0 

□ 

modifier 

supprimer 


Figure 9-36 

Notre menu a present proprement structure 


Voila qui est mieux. II ne nous reste des lors quune seule chose a faire, 
afficher le menu. Pour cela, retournez dans la gestion des blocs, et si vous 
regardez bien dans la region Desactive, vous devriez y decouvrir un nou- 
veau bloc La societe. 


Desactive Figure 9-37 

4+ La societe | <aucun;» c | configurer Un menu est 3USSi Un blOC. 


223 


www.frenchpdf.com 


- Structurer les 


Drupal 6 - Concevoir et deployer ses applications 


£ 


C’est une fonctionnalite tres pratique du systeme de menu de Drupal : 
tout nouveau menu cree donne lieu a la creation dun bloc equivalent 
pour son affichage. Faites maintenant glisser le bloc jusqu’a la region 
Barre de droite et placez-le juste derriere le bloc Description de la 
societe, puis enregistrez. 

Nous allons maintenant modifier la configuration de ce bloc. Tout 
d’abord, afin qu’il beneficie dun titre un peu plus representatif comme 
« La societe Colchique », vous pouvez soit modifier ici son titre, soit 
retourner dans la configuration du menu La societe pour le modifier a cet 
endroit. Pour plus de simplicity, nous allons changer le titre dans la con- 
figuration du bloc. 

Figure 9-38 T ,t re dubioc: 

Donnons un titre un peu plus explicite [ Las0 ciete colchique 

a notre bloc La societe. Modifiez le titre pardefautdu bloc. Indiquez (<nc 


Vous devez en outre parametrer ce bloc pour quil ne soit affiche que sur 
les pages autres que faccueil. 

A ff ic her le bloc sur certaines pages seulement : 

® Afficher le bloc surtoutes les pages exceptees celles listees. 

O Afficher le bloc seulement sur les pages listees. 

O Afficher si le code PHP suivant retourne TRUE (mode PHP : experts seulement). 


Figure 9-39 

Definition de la visibilite du bloc La societe 


Pages : 

<front>| 


Lorsque tout est en place, vous pouvez enregistrer et verifier que le 
rendu du bloc vous convient. 


I I — 

Gontactez nous Deconnectez-vous 

Nos Publications Les Billets FAQ 



Figure 9-40 

Le bloc-menu La societe en place 


La societe Colchique 

^ Qui somme s-nous ? 

O Nos valeurs 
° Llequipe 
° Historique 
° Les chiffreset dates 


Et voila, notre menu est desormais actif et utilisable. 
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En resume 

• Les blocs sont des unites de contenu qui peuvent etre crees dynami- 
quement par des modules, ou que Ton peut creer soi-meme comme 
n importe quel contenu. 

• Une region est une zone de la page sur laquelle peuvent etre disposes 
des blocs. 

• Les regions sont definies par le theme. 

• Un meme bloc ne peut etre dans deux regions differentes. 

• Changer la structure d une page consiste en parti culier a jouer sur la 
visibility des blocs qui la composent. 

• Un menu Drupal est un groupe contenant des elements de menu. 

• Chaque menu peut etre transforme en bloc. 


O'! 
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Active 

Code 

Nom anglais 

Nom natif 

Direction 

Par de taut 

Poids 

Operations 

0 

en 

English 

English 

De gauche adnoite 

o 

1° =1 

editer 

0 

fr 

French 

Franc; ais 

De gauche adroite 

* 

1° :s l 

editer 
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Gerer les langues 


Drupal est un produit developpe par des personnes venant des 
quatre coins de la planete. Ce nest done pas une surprise de 
constater que ce CMS dispose d un support de langues tres 
evolue. Nous aborderons ci-apres l’ensemble des dispositifs 
dont il dispose pour traduire dynamiquement dans une langue 
donnee ses interfaces, et meme ses contenus. 


SOMMAIRE 

► Installer de nouvelles langues 

► Traduire les interfaces 

► Creer un site multilingue 

► Amelioration des traductions 
existantes 

► Fournir un contenu multilingue 
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Traduction des contenus et traduction 
des interfaces 

La gestion des langues de Drupal se segmente en trois concepts : 

• les langages utilises pour l’interface : il s’agit la des menus, des mes- 
sages d’erreur ou divertissement, et dune maniere generate de tous 
les textes que fournissent les modules ; 

• les langages des contenus : ceci correspond a la possibility de disposer 
dun meme contenu en plusieurs langues ; 

• la liste des langues prises en charge par le site : que ce soit pour tra- 
duire l’interface ou definir un contenu dans une langue donnee, le 
nom de cette langue doit etre prealablement ajoute a cette liste. 

De ces trois points, nous pouvons deduire trois possibility bien evidem- 
ment combinables : 

• vous desirez traduire certaines expressions encore en anglais dans 
l’interface. Ce cas est typique lorsque 1’ on installe de nouveaux 
modules, ils ne sont pas - loin sin faut - tous traduits ; 

• vous desirez donner a vos visiteurs la possibility de changer la langue 
de Tinterface (les menus, les messages, etc.) ; 

• vous desirez proposer des contenus dans plusieurs langues. 

Tout cela est possible avec Drupal, et nous allons voir comment en com- 
men 9 ant par explorer l’ajout de nouvelles langues, puis de nouvelles tra- 
ductions d’interface, pour nous interesser enfin a la traduction des 
contenus eux-memes. 


Bon A savoir Qui fait les traductions ? 

Le travail de traduction ne fait pas partie du deve- 
loppement de Drupal en lui-meme mais est 
delegue a chaque association de Drupaliens dans 
chaque pays. La qualite de la traduction dans une 
langue donnee est done directement liee au 
nombre de personnes qui prennent benevolement 
et regulierement de leur temps pour I'ameliorer. 

En France, les traductions sont gerees sur le site 
http://HOn.drupalfr.org/. C'est a cet endroit que 
vous pourrez vous aussi contribuer si vous le sou- 
haitez. 


Traduction des interfaces 

La liste des langues 

Drupal a besoin de connaitre la liste exhaustive de toutes les langues qui 
vous sont necessaires. Quel que soit l’usage que vous en ferez, si vous 
avez besoin d utiliser une nouvelle langue, vous devez avant toute chose 
Taj outer a la liste des langues du site. 

Pour acceder a la liste des langues, dirigez-vous vers Configuration du site , 
puis Toutes les langues. Sur cette page sont listees les langues actuelle- 
ment connues du systeme : Tanglais et le fran^ais. 
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Active 

Code 

Nom anglais 

Nom natif 

Direction 

Par defaut 

Poids 

Operations 



en 

English 

English 

De gauche adroite 

o 

(° S 1 

editer 

Figure 10-1 

Le panneau de selection 
des langues actives 

0 

fr 

French 

Franc; ais 

De gauche adroite 


(° 5 ) 

editer 


Rien d’etonnant a cela car, comme nous le disions en introduction, 
l’anglais est la langue maternelle de Drupal. Quant au fran^ais, nous 
l’avons explicitement active lors de l'installation. 

Sur ce panneau, nous avons deux colonnes interessantes, avec tout 
d’abord Active qui indique que la langue est utilisable dans le systeme. La 
seconde colonne, Par defaut, indique quelle langue Drupal utilise par 
defaut (ici, le fran^ais). 

Puisque les deux langues sont activees, cela signifie que nous pouvons 
basculer l’interface de l’anglais vers le fran^ais et vice versa. Pour cela, 
nous allons devoir instruire Drupal sur la maniere de choisir une langue 
ou une autre. 

Negodation de la langue 

Plusieurs procedes permettent a Drupal de savoir s’il doit afficher des 
interfaces en fran^ais ou en anglais. II peut s’appuyer sur le nom de 
domaine du site en utilisant le fran^ais pour http://www.colchique-conseil.fr et 
l’anglais pour http://www.colchique-conseil.com. II peut egalement detecter la 
langue qui a ete definie comme preference par defaut dans votre naviga- 
teur, et futiliser (sur Mozilla Firefox, ce choix est defini dans les Prefe- 
rences, onglet Contenu et section Langues). Enfin, il peut utiliser une 
methode fondee sur le chemin et decider, par exemple, que tous les che- 
mins commen^ant par /en/ (ex. http://www.colchique-conseil.fr/en/node/l) cor- 
respondent a la langue anglaise et /f r/ a la langue frar^aise (ex. http:// 
www.colchique-conseil.fr/fr/node/l). 

Le choix dun de ces procedes a pour nom la « negodation de la 
langue », et son parametrage est accessible en cliquant sur fonglet Confh 
gurer de la page ou nous nous trouvons. 


Negodation de la langue : 

® Aucun. 

O Seulement le prefixe de chemin. 

O Prefixe de chemin avec solution degradee. FigilTG 10—2 

O seulement le nom tie domaine. Choix du mode de negotiation des langues 
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• Dans le mode Aucun, la langue ne change simplement jamais. 

• Dans le mode Seulement le prefixe de chemin , la langue est determinee 
par le debut du chemin (le /en/ ou /f r/ mentionnes plus haut) qui 
est appele « prefixe ». 

• Dans le mode Prefixe de chemin avec solution degradee , la langue est 
determinee comme dans le cas precedent, mais si aucun prefixe n est 
present dans le chemin, ce sont les parametres de lutilisateur (dans 
Mon compte ) qui seront utilises. Si futilisateur est anonyme, c’est la 
langue du navigateur qui sera utilisee. Enfin, si le navigateur n a pas 
de langue definie, c’est la langue par defaut qui sera utilisee. 

• Pour finir, dans le mode Seulement le nom de domaine , la langue est 
determinee par le nom de domaine utilise. 

Choisissons pour notre exemple la negociation Prefixe de chemin avec 
solution degradee puis enregistrons ces parametres. 

O Aucun. 

Figure 10-3 O Seulement le prefixe de chemin. 

Choix du mode de negociation ® Prefixe de chemin avec solution degradee. 

par chemin avec solution degradee q Seulement le nom de domaine . 


Reglage des prefixes 

URL specifiques 

Avant de poursuivre, vous remarquerez que l’adresse de la page dans le 
navigateur a automatiquement change. 

Figure 10-4 

L'adresse du site prend en compte I i http://w ww.colchique-conseil.fr/fr/admin/settings/language 

le prefixe de langue. 

Drupal a en effet pris en compte notre choix de la strategic « par prefixe » 
et a en consequence insere le prefixe de la langue fran^aise dans le chemin. 

Pour voir d’ou vient ce /f r/, retournez sur la liste des langues et cliquez 
sur le lien editer de la langue fran^aise. 

Comme vous le voyez, le prefixe de la langue franchise est bien f r. En 
revanche, si vous effectuez la meme operation sur la langue anglaise, 
vous constaterez que le champ Prefixe de chemin est vide. Cela veut dire 
que lorsque aucun prefixe ne figure dans le chemin - ce qui est la situa- 
tion par defaut -, il y aura de fortes chances que notre site s’affiche dans 
la langue de Shakespeare. Pour remedier a cela, inversons la situation en 
saisissant en comme prefixe pour la langue anglaise et en vidant le 
champ prefixe pour la langue fra^aise. 
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Prefix* cle chemin : 


[ fr I 

Code de la langue ou n'importe quel autre chaine de caractere a identifier dans le chemin d'ac 
seii'/emertf o u Prefixe de chemin avec fallback, le site sera presente dans cette langue lorsque le 
restervide. Toute modification de cette valeur peutcasser les URLs existantes, et doit done e 
chemin pour le fran$ais se traduira par des URLs de la forme "www. example, com/french/node" . 

Domain* de la langue : 


URL specif ique a la langue, incluant le protocole. Si le parametre de negociation de la langue 
contiendrace domaine. Pour la langue par defaut, ce parametre peut restervide. Cette valeur ■ 
"httpy/fr. ex ample.com" comme domaine pour la langue franqaise se traduira par des URLs de la f 

Direction : * 

® De gauche a droite 
De droite a gauche 

Direction d'ecriture du texte. 


Figure 10-5 

Parametrage de la langue 


Une fois les parametrages enregistres, il est probable que Drupal vous 
renvoie une erreur 404 (la page n’existe pas). Pas de panique, e’est tout a 
fait normal car le /fr/ est reste dans l’adresse et ne correspond done plus 
a rien. Retournez a l’accueil et revenez sur la page Toutes les langues, 
l’adresse devrait maintenant etre correcte. 

A noter que si vous avez choisi la strategic Seulement le nom de domaine , 
e’est dans ce meme formulaire que vous aurez saisi chacun des domaines 
pour chaque langue (ex. www.colchique-conseil.com pour l’anglais). 

Changer de langue 

Pour tester le passage dune langue a l’autre, nous disposons a present de 
deux solutions : soit nous modifions le chemin manuellement en insu- 
rant au debut le /en/, ce qui n’est pas tres pratique, soit nous ajoutons un 
bloc permettant au visiteur de basculer d’une langue a l’autre. 

Pour realiser cette seconde option, vous devez aller dans l’administration 
des blocs, ajouter a la region Bane de droite le bloc Selecteur de langue qui 
existe en standard, puis enregistrer les blocs. 


Barre de droite Figure 10~6 

*3+ Selecteurde langue* [ Barre de droits C~] configurer Activation du SeleCteUT de langue 

Vous devriez alors voir apparaitre un nouveau bloc de gestion des lan- 
gues. 


Toutes les langues 

Figure 10-7 

Fran c ais Le Selecteur de langue 
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Cliquons maintenant sur English pour voir si tout fonctionne correcte- 
ment. Normalement un /en/ doit apparaitre dans FURL. 


<v 

£ 


Figure 10-8 

L'URL contient le prefixe /en/ 
signifiant la langue anglaise. 


5 


htt p ://www . c ole h iqu e-c on s ei I . frf en/adm i n/s etting s/I ang u ag e 


L’interface du site doit etre a present entierement traduite en langue 
anglaise. 


Figure 10-9 

Le menu Navigation est 
maintenant traduit en anglais. 


administrateur 

My account 
Translate strings 
Create content 
'u ? Administer 

Co nte nt m an age me nt 
Site building 
S7 Site configuration 
Actions 


Le choix du mode de negociation Prefixe de chemin avec solution degradee 
presente ici de nombreux avantages : 

• s’il y a un prefixe dans FURL, le site utilise la langue correspondant a 
ce prefixe ; 

• si aucun prefixe ne figure dans FURL et que lutilisateur est authen- 
tifie, Drupal utilise la langue choisie dans M on compte pour afficher 
la bonne interface. Pour un utilisateur anonyme, il utilisera les prefe- 
rences selectionnees dans le navigateur web ; 

• enfin, sans prefixe dans FURL et en Fabsence de preferences utilisa- 
teur detectees, Drupal utilise la langue par defaut - ici le fran^ais. 

Avec ce parametrage, notre site fonctionnera comme avant tout en offrant 
de nouvelles possibility, dont celle d’ajouter encore une nouvelle langue. 

Ajout d’une nouvelle langue 

Nous allons a present aj outer une troisieme langue, Fesperanto. Tele- 
chargeons Farchive de cette langue sur http://drupalfr.org, dans la section 
Downloads puis Translations, comme nous Favions fait pour le fran^ais 
lors de F installation de Drupal. 

Une fois Farchive en main, decompressez-la dans le dossier Drupal. 
Ensuite, cliquez sur Fonglet Ajouter une langue et selectionnez Esperanto. 
Comme vous le constatez, la liste des langues connues de Drupal est 
longue, ce qui nimplique pas pour autant Fexistence d’une traduction 
pour chacune d’elles. 
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Esperanto 

By amuzulo on the 3rd of November, 2004 

Drupal interface translation to the international language Esperanto. 
Traduko de la interfaco de Drupal en Esperanto. 


Version 

Date 

Links 

Status 


6.X-1.0 

2008-May-31 

Download ■ Release notes 

Recommended for 6.x 


5.x-l.x-dev 

2008-May-31 

Download ■ Release notes 

Development snapshot 

© 


Find out more ■ Bugs and feature requests 


Figure 10-10 Telechargement de I'archive de langue esperanto 


V Langue predef in ie 

Nom de b bngue : 

j Esperanto o"j 

Se lectio n ne r la langue deairee et cllquez sur le b 
iBte). 

| Ajouter une langue | Figure 10-11 

Ajout de I'esperanto comme langue d'interface 


Cliquez maintenant sur Ajouter une langue. Le moteur de traduction de 
Drupal se met alors en route pour traduire l’interface. 


Accueil 

Importation de traductions de I'interface utilisateur 


Reste 17 sur un total de 25. 


Figure 10-12 

La barre de progression 
de traduction de I'interface 


Une fois I’interface entierement traduite, nous sommes renvoye sur la 
liste des langues avec un nouvel arrivant, I’esperanto ! 


Active 

Code 

Nom angbis 

Nom natif 

Direction 

Pardefaut 

Poids 

Operations 


0 

en 

English 

English 

De gauche adnoite 

o 

1° I®] 

editer 

Figure 10-13 

L'esperanto est maintenant 

0 

eo 

Esperanto 

Esperanto 

De gauche adnoite 

o 

1° ») 

editer supprimer 

0 

fr 

French 

Frangais 

De gauche adnoite 

@1 

1° =J 

editer 

une langue de Drupal. 


Vous remarquerez que cette nouvelle langue a ete automatiquement 
activee. Vous pouvez jeter un coup d’oeil sur le bloc de selection des lan- 
gues pour verifier que I’esperanto s’y trouve effectivement, et de la, cli- 
quer sur le lien Esperanto pour traduire I’interface. 
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Figure 10-14 

Et void le menu de navigation en esperanto ! 


Mia konto 
Translate strings 
Krei enhavon 
Administri 

Enhava mastrumado 
Rebsja konstruado 


Vous noterez que FURL a pris le prefixe /eo/, qui est le prefixe configure 
automatiquement pour la langue esperanto. Dans le Selecteur de langue, 
cliquez maintenant sur Frangais pour revenir a l’etat standard. 


Modules MAGIQUES Reimporter des traductions mises a jour 

Pour disposer d'une nouvelle langue, nous avons jusqu'a present telecharge une archive de 
traduction, nous I'avons decompressee a la racine du site et enfin ajoutee a la liste de Drupal. 
Ceci est parfait mais que se passe-t-il lorsque une traduction a ete amelioree et qu'il existe 
une nouvelle version ? Comment faire pour que Drupal « relise » les traductions ? En stan- 
dard, rien n'existe pour « rafraichir » une traduction et il nous faut pour cela installer le 
module Localization Client. 

► http://drupal.org/project/l1 On_client 

Un fois le module active, la marche a suivre pour mettre a jour une langue commence evidem- 
ment par le telechargement et la decompression a la racine de Drupal de la nouvelle version 
des traductions. Si votre outil de decompression demande d'ecraser d'anciens fichiers, 
n'hesitez pas, c'est le but de la manoeuvre. 

Ceci fait, allez dans Construction du site > Traduction de I’interface, puis dans I'onglet 
Importer ; vous decouvrirez un sous-onglet Reimport packages. Dans cet onglet, selec- 
tionnez la langue a mettre a jour puis cliquez sur Reimport packages. Une fois le travail 
acheve, les nouvelles traductions sont prises en compte par Drupal. 


Nous pouvons ainsi aj outer a notre site autant de langues que necessaire, il 
n’y a aucune limitation. Notez egalement que nous aurions pu ajouter une 
langue sans pour autant installer un paquet de traduction. En effet, nous 
pourrions avoir besoin de l’esperanto pour disposer, par exemple, de la 
possibility de traduire des contenus dans cette langue, sans pour autant 
avoir besoin d une interface en esperanto. En realite, cette liste presente 
toutes les langues disponibles et gerees par Drupal pour votre site ; il vous 
appartient ensuite de decider si telle langue sera utilisee pour des traduc- 
tions d ’interface ou des traductions de contenus, ou les deux. 


Ajout d’une traduction 

Jusqu’a present, nous nous sommes contente de decompresser des 
archives de traduction pretes a l’usage. Voyons maintenant comment 
ajouter de nouvelles traductions, par exemple comment transcrire en 
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O) 

3 

Ol 

c 

JS 

frangais une chaine de caracteres qui subsisterait encore seulement en 
anglais dans l’interface. 

Lorsque nous avons aborde la gestion des droits d’acces, nous avons cons- 
tate que de nombreuses expressions etaient encore en anglais, comme 
create billet content. Pour traduire ce terme en fra^ais, dirigez-vous vers 
Construction du Site > Traduction de I’interface. Vous arrivez alors sur une 
page indiquant le statut de chacune des langues installees. 


Lang ue 

Anglais (interne) 

Esperanto 

Frangais 


Bon a savoir 

Rechercher des expressions variables 

Si vous desirez chercher un terme de maniere plus 
etendue, comme tout ce qui commence par 
« create » et finit par « contenu », vous pouvez 
utiliser le caractere %, ce qui nous donnera 

create % content. 


® A lafois les chaines traduites et celles qui ne 
O Seulement les termes traduits 
O Seulement les termes non traduits 

Limiter la recherche a : 

® Tous les groupes de texte 
O Interface utilisateur 

Recherche 


Figure 10-16 

Recherche d'une expression non traduite 


Nous y voyons que 90,95 % des traductions fran^aises sont realisees, ce qui 
n est pas mal du tout pour un travail exclusivement effectue par des bene- 
voles. Mais il reste encore 9 % des textes en anglais, ce qui n est pas un 
probleme en soi car cela signifie que la majorite des instructions visibles 
par un visiteur ont ete traduites. La plupart du temps, ce taux residuel de 
textes non traduits est lie a des modules complementaires ayant ete ins- 
talles et ne disposant pas de traduction fran^aise pour leur interface. 

Pour traduire l’expression create billet content , nous devons cliquer sur 
l’onglet Recherche et la saisir dans le champ La chaine contient. 

Avant de valider, nous selectionnons les options Toutes les langues , Seule- 
ment les termes non traduit et Tous les groupes de texte. 

La chaine contient : 

[create billet content 

Laisser vide pour afficher tous les termes. La recherche esl 

Lang ne : 

® Toutes les langues 
■ . 1 Anglais (fourni par Drupal) 

O Esperanto 
O Frangais 

Rechercher dans : 


Interface utilisateur 

nd 

3764/6034 ( 62 . 38 %) 
5488/6034 ( 90 . 95 %) 


Figure 10-15 

Statut de traduction par langue 
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Ensuite, appuyez sur le bouton Recherche pour obtenir la liste des resultats. 


Figure 10-17 

Resultat de la recherche 
de I'expression non traduite 


Figure 10-18 

Ajout de la traduction manquante 


Figure 10-19 

Le texte est maintenant correctement traduit. 


Modules magiques 

Un client de traduction dynamique 

Le module Localization Client, que nous avons 
decouvert dans le precedent aparte « Modules 
magiques », a pour role premier de vous permettre 
une traduction dynamique de I'interface. Une fois 
le module active, vous disposez, en has a droite de 
chaque page, d'un bouton Translate. En cliquant 
sur ce lien, un panneau de traduction de 
I'ensemble des termes de la page apparait. Vous 
pouvez ainsi traduire ou corriger des traductions 
de maniere simple et intuitive. Les modifications 
sont automatiquement sauvegardees. 

► http://drupal.org/project/l1 On_client 


Groupes de texte 

Interface utilisateur 


C Maine 

create billet content 

/ ad m i m' us e n 1 p e rm iss i o ns 


Toutes les langues 
SGfF 


Operations 
modifier supprimer 


Dans la colonne Toutes les langues figurent en barre les langues pour les- 
quelles il n existe actuellement pas de traduction de notre expression. 
Nous allons en ajouter une en cliquant sur modifier. 

Nous ne saisirons ici - faute de competences - que la version franchise de 
ce terme, puis cliquerons sur Enregistrer les traductions. 

Modifier le terme 

Texte original : 

create billet content 

Esperanto : 



Nous pouvons maintenant verifier que notre nouvelle traduction a cor- 
rectement ete prise en compte en retournant dans le panneau de confi- 
guration des droits d’acces. 

administrer les noeuds 
Greer un contenu de type billet 
create page content 

Cela fonctionne parfaitement ; nous pouvons ainsi traduire tous les mes- 
sages encore affiches en anglais dans finterface, en ciblant en priorite les ele- 
ments importants, c’est-a-dire ceux qui sont visibles par tous les utilisateurs. 


Bon A savoir Utiliser directement les fichiers .PO 

Une methode plus avancee de traduction consiste a utiliser la fonction d'import/export. En 
exportant une langue, vous obtiendrez un fichier texte au format PO. Ce format est un clas- 
sique de la traduction dans le monde des logiciels libres. II existe de tres nombreux logiciels 
sur toutes les plates-formes (par exemple, PoEdit - http://www.poedit.net) permettant 
d'editer facilement ces fichiers. Une fois les traductions faites, vous pouvez a nouveau 
importer le fichier PO dans Drupal. 

Nous I'avons vu plusieurs fois deja, les traductions de Drupal sont le travail de benevoles, et un 
gros travail qui plus est. Si vous trouvez des erreurs, des manques ou des imprecisions, n'hesitez 
pas a contribuer. Nous disposons pour cela d'un site frangais totalement dedie aux traductions. 

► http://HOn.drupalfr.org/ 
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Traduction des contenus 


Comme les interfaces, les contenus peuvent exister en plusieurs langues, 
et comme pour les traductions d ’interface, la premiere chose a faire pour 
traduire un conte nu dans une langue donnee est d’aj outer cette langue 
dans la liste Toutes les langues. Dans l’exemple qui va suivre, nous propo- 
serons une version anglaise de l’article de bienvenue. Un ajout ne sera 
done pas necessaire puisque la langue figure deja dans la liste des langues 
connues de Drupal. 

Pour utiliser la traduction des contenus de Drupal, il convient tout 
d’abord de verifier que le module Content translation (dans la section 
Core - facultatif) est bien active. C’est en effet ce module qui va per- 
mettre la traduction puis l’affichage d’un noeud dans une langue donnee. 

Nous devons ensuite decider quels types de contenu peuvent etre tra- 
duits, et pour cela, retournons dans le panneau maintenant connu d’edi- 
tion des types de contenu. Nous allons dans notre exemple modifier le 
type de contenu Article. 

Deployez la section Procedure de publication pour y decouvrir un nouveau 
champ Gestion multilingue proposant plusieurs choix : 

• Desactive est l’etat standard, ce type de contenu ne sera pas 
traduisible ; 

• Active va ajouter un champ langue a tous les contenus de type Article ; 

• Enabled, with translation : oups... void un oubli de traduction que vous 
savez desormais corriger. Cette option a les memes effets que Active 
mais ajoute au contenu une serie de fonctions permettant de gerer ses 
traductions. C’est le choix que nous allons faire. 


Gestion multilingue : 

O Desactive 
O Active 

* E n ablecl, with tran s I ati o n 


Figure 10-20 

Activation du mode multilingue pour les contenus de type Article 


Vous pouvez maintenant enregistrer le nouveau parametrage du type de 
contenu Article. 

Derniere etape, comme toujours lorsque nous ajoutons un nouveau 
module, nous devons a present ajouter les droits correspondants. Ici, il 
s’agit d’oetroyer la permission Translate Content au role Contributeur, 
sans quoi Marine ne pourrait pas traduire l’article de bienvenue. 

Il est maintenant temps de se deconnecter pour se reconnecter en tant 
que Marine et de modifier l’article de bienvenue. 
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L’edition de ce premier article a traduire nous permet de verifier les nou- 
veaux parametrages effectues. Nous trouvons effectivement un nouveau 
champ Langue qui, par defaut, a ete initialise a Francis. Si ce n est pas le 
cas, corrigez cela, puis enregistrez le contenu. 


Figure 10-21 Langue : 

Choix de la langue de Tarticle Frangais 


Nous remarquons aussi fapparition d un nouvel onglet Translate (encore 
un terme en anglais a corriger) sur lequel nous cliquons pour aj outer la 
traduction anglaise. Apparait alors une liste de langues indiquant celles 
pour lesquelles la traduction existe deja, et pour le moment, nous n avons 
evidemment que le fran^ais. 


Figure 10-22 

Le statut des traductions disponibles 
pour un meme article 


Langue 

English 
Esperanto 
French (source) 


Trtre Statut Operations 

nd Not translated add translation 

nd Not tran s I ated add tran s I atio n 

Bienvenue Publie editer 


L’annotation (source) nous indique que cet article est le parent des 
futures traductions. Nous pouvons alors cliquer sur add translation sur la 
ligne English , et creer une version anglaise (ou esperanto si vous vous 
exprimez couramment dans cette langue). 

Nous arrivons alors sur une page tres classique de creation de contenu 
avec la langue en grise, ce qui est logique car Drupal a memorise que 
nous sommes en train de traduire ce noeud en anglais. Vous pouvez 
maintenant commencer votre version. Pour vous aider dans cette tache, 
Drupal preremplit fintroduction et le corps de farticle avec la version 
source (ici fran^aise). 

Lorsque vous avez termine, enregistrez votre travail sans oublier de 
cocher Publie mais pas Promu en page d'accueil. Sinon, vous aurez en page 
d’accueil les deux articles dans les deux langues. 

Welcome ^ Modifier Translate 

Le contenu 'Welcome', de type 'Article', a ete cnee. 

Figure 10-23 

Le contenu est maintenant ven.o&ia^oog- ii:is- Marine 

disponible en anglais. Welcome to Colchique Gonseil, 
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Si nous cliquons a nouveau sur l’onglet Translate , nous constatons le tra- 
vail realise. 


Langue 

Tit re 

Statut 

Operations 

English 

Welcome 

Non publie 

editer 

Esperanto 

nd 

Not translated 

add translation 

French (source) 

Bienvenue 

Publie 

editer 


Figure 10-24 

Le statut de traduction pour ce contenu indique maintenant 
la presence de la langue anglaise. 


Notre article est maintenant disponible dans deux langues, et nous allons 
de ce pas verifier que la traduction des contenus a fonctionne correcte- 
ment. Pour cela, cliquez sur le lien Biem/enue. 


Bienvenue 


Modifier Revisions Translate 


mer, 06/03/2009 -01:38 — Marino 
Bienvenue sur le site de Colchique Conseil. 

le cabinet de conseil en ressources humaine qui a \'ethique a coeur . 

Vo us tnouvenez sur notre site une presentation complete de la societe, de ses 
intervenant et de ses valeurs. Vous pourrez aussi y decouvrir nos publications ainsi que 
nos billets d'humeur. 

Bonne visite 

L'equipe de http://www.colchique-conseil.fn]!?. 


Fie hie r attache 

Taille 



copie dlecran.png 

1 05.4 Ko 



Manuel utilisateur.pdf 

274.03 Ko 


Figure 10-25 




L'article en mode complet avec le lien 

English 


Recrutement 

permettant de passer a la version anglaise 


Vous remarquez sous le contenu en fran^ais fapparition dun nouveau 
lien English. Ce bouton agit comme un selecteur de langue et basculera le 
contenu, mais aussi finterface, en anglais. Cliquez sur ce lien pour bas- 
culer vers la langue anglaise. 


Welcome Edit Translate 

Fri. 06/19/2009 - 11:18 — Marine 
Welcome to Colchique Conseil, 


Figure 10-26 

Traduction automatique du contenu 
en fonction du contexte de langue 


Modules magiques 

La Rolls de I'internationalisation 

Le systeme de traduction de Drupal convient par- 
faitement aux usages basiques, mais montre ses 
limites lorsqu'il s'agit de creer un site entierement 
multilingue. En effet, dans un tel cas, vous allez 
vouloir disposer d'une traduction non seulement 
pour les contenus et les interfaces, mais aussi pour 
vos menus personnalises, vos blocs, vos taxono- 
mies, etc. L'ensemble de ces taches supplemen- 
taires est realise par le module II 8N. 

► http://drupal.org/project/i18n 


Lmterface et la langue du contenu ont maintenant change. Nous remar- 
quons egalement que les commentaires ont disparu. En effet, les com- 
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mentaires sont lies au conte nu dans une langue donnee. Avec deux 
langues, vous aurez done deux jeux de commentaires. 


Module magique Une alternative 
pour une page d'accueil multilingue 

Pour ceux qui ont choisi d'utiliser le module II 8N, 
cette possibility de definir une page d'accueil 
n'affichant que les contenus dans la langue de 
I'interface est integree au module. Ceci etant dit, 
II 8N est un gros module qu'il convient de n'utiliser 
que si Ton en a besoin, le cas echeant, la tech- 
nique utilisant Views reste la plus efficace. 


Astuce 

L'utilisation de Views n'est justifiee que par le fait 
de vouloir reproduire en version multilingue le 
comportement standard de la page d'accueil de 
Drupal. Vous avez, si vous le desirez, la possibility 
de faire exactement la meme chose en remplagant 
la premiere etape par la creation de deux noeuds 
de type Page et en utilisant leurs permaliens 
(node/XXX) a la place de f rontpage_en et 
f rontpage_f r pour les deux etapes suivantes. 


Page de garde multilingue 

Si nous cliquons a present sur le lien Home (anciennement Accueil), nous 
constatons que la page de garde est un melange d'anglais et de fra^ais. 
Ce n est pas etonnant car le fonctionnement standard de Drupal est 
d'afficher en page d'accueil tous les contenus possedant le statut Promu 
en page d'accueil. Voyons comment nous pouvons creer, a partir de ce que 
nous disposons, deux pages d'accueil, l'une en fran^ais et l'autre en 
anglais, chacune avec une liste de contenus specifiques a la langue, et 
surtout comment faire pour que le changement de langue implique le 
changement de page d'accueil. 

La solution pour creer ces deux pages d'accueil commence par l'utilisation 
du module Views. II s'agira alors de creer deux vues, la premiere affichera 
la liste des noeuds de langue anglaise, et l'autre celle de langue fran^aise. 

Pour fabriquer ces vues, vous pouvez simplement dupliquer la vue Arti- 
cles que nous avons precedemment creee, et la renommer f rontpage_f r. 
Ceci fait, nous allons commencer par supprimer le filtre sur le Type de 
noeud et le remplacer par un filtre sur la langue du contenu, Node transla - 
tion , avec comme critere Langue = Franfais. 

Cliquez ensuite sur l'onglet Page , et changez le chemin pour 
f rontpage_f r. Changez enfin le titre pour simplement le vider de son 
contenu. Une fois tout cela fait, enregistrez la vue. 

Dupliquez cette nouvelle vue et appelez la cette fois-ci f rontpage_en ; 
changez la langue du filtre pour l'anglais et le chemin pour qu'il 
devienne cette fois f rontpage_en. 

L'etape suivante consiste a ajouter deux alias sur les chemins de nos vues 
en passant par Construction du site , puis Alias d'URL. Cliquez sur l'onglet 
Ajouter un alias. Notez un point important : la presence d'un menu 
deroulant avec une liste de langues, qui nous permettra de rendre notre 
alias dependant de la langue en cours. 

Pour cela, nous allons creer un premier alias de langue fran^aise prenant 
f rontpage_f r comme Chemin systeme existant et frontpage comme Alias 
de chemin. 
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Lang Lie : 

| Frangais 0 | 

A p ath al i as s Et f □ r a s p b c iftc language will al w ays be used when d is p I ayi n g th is page i n th at I an g u ag e , and' 

Chemin systeme existant : * 

http://wvwv.colchique-conseil.fr/ |frontpage_fr | 

Specifier le chemin existant que vdus souhaitez renommer par un alias. Parexemple : nadsi'ZB, forum^l, tax 

Alias de chemin : * 

http://wvwv.colchique-conseil.fr/ [frontpage j 

Specifier un chemin alternatif par lequel cette ressource peut etre accedee. Parexemple, taper "about' qua 
ai outer de slash final ou I' alias d'URL ne fonctionnera pas. 

Figure 10-27 

1 creer un nouvei alias Saisie de I'alias pour la langue frangaise 


Cliquez maintenant sur Creer un nouvei alias , et renouvelez l’operation 
avec cette fois-ci une langue anglaise, un chemin f rontpage_en et - c’est 
la toute l’astuce - le meme alias frontpage. Une fois enregistre, nous dis- 
posons done de deux alias strictement identiques, juste differencies par la 
langue. 

La derniere etape pour completer le dispositif consiste a se diriger vers 
Configuration du Site > Information. Nous y trouvons un reglage particu- 
lierement utile a la fin du formulaire : Page de garde par defaut. Comme 
l’intitule le suggere, ce reglage permet de determiner quel est le chemin a 
utiliser lorsque le visiteur cherche a visualiser la page d’accueil. Atten- 
tion, c’est un peu delicat car il ne s’agit pas de rediriger la page d’accueil 
vers un chemin mais bien d utiliser le chemin comme page d’accueil. En 
d’autres termes, l’URL ne changera pas, mais le contenu de la page, si. 

Par defaut, la valeur est node signifiant que la page d’accueil affiche la 
liste des noeuds. Changez cette valeur pour la remplacer par notre alias 
frontpage. Ainsi, la page d’accueil utilisera le chemin frontpage, un alias 
dependant de la langue, comme contenu d’affichage. 

Enregistrez le parametrage et cliquez sur Accueil. Vous obtenez bien la 
vue f rontpage_f r car nous sommes pour l’instant en interface franchise. 
Cliquez maintenant sur le lien English du Selecteur de langue, et l’accueil 
passe comme prevu en anglais. 


En resume 

• Les traductions disponibles sont le fruit d’un travail communautaire, 
n’hesitez pas a y participer en creant un compte sur http://HOn.drupalfr.org/. 

• Drupal en standard prend en charge une traduction des interfaces et 
des contenus. Si vous souhaitez aller plus loin, le module I 18 N est un 
passage oblige. 
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Modifier I'apparence 


Comme nous l’avons mentionne dans Introduction 
du chapitre « Structurer les pages », le second axe de travail 
pour personnaliser I’apparence d’un site Drupal passe 
par l’utilisation de son moteur de theme. Ce moteur dune 
grande souplesse permet a notre site de se plier a toutes 
les contraintes de charte graphique. Mais qui dit grande 
capacite dit aussi apprentissage, et pour rendre apprentissage 
le plus progressif possible, nous avancerons graduellement 
en trois etapes, en partant de la simple configuration 
d’un theme existant pour arriver a la fabrication d’un theme 
qui vous est propre et entierement personnalise. 


SOMMAIRE 

► Comprendre les themes, 
les moteurs de theme 
et les modeles 

► Parameter les themes existants 

► Creer son propre theme 

► Construire ses propres modeles 

► Ajouter des fonctions avancees 
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Qu’est-ce qu’un theme ? 
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Un theme, ca change tout ! 

Une maniere simple et visuelle pour comprendre ce qu est un theme 
Drupal consiste a se rendre sur le site http://www.drupalsites.net/drupal-top-sites. 
Vous avez ici un ensemble de sites web, avec une vignette donnant pour 
chacun un petit apercpi de son apparence visuelle. Cliquez sur le bouton 
GO! de quelques-unes de ces vignettes au hasard... 


Figure 11-1 

Les vignettes des differents sites 
utilisant Drupal 
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Au-dela des gouts et des couleurs, pouvez-vous imaginer qu il s’agisse a 
chaque fois du meme Drupal ? Et pourtant, la construction de l’ensemble 
de ces sites a suivi un processus semblable a celui que nous avons adopte 
jusqu ici ; la seule difference reside dans la personnalisation du theme. 

Pour se donner une meilleure idee de ce qu’il est possible d’obtenir avec 
un meme Drupal, void quelques autres sites : 

• http://research.yahoo.com/ 

• http://www.mediapart.fr/ 

• http://myplay.com/ 

• http://www.laquadrature.net/ 

• http://www.observer.com/ 

Theme et moteur de theme 

Le systeme de themes de Drupal se compose de deux elements : un 
theme et un moteur de theme. 

Un moteur de theme est un element quil est possible d’installer dans 
Drupal a la maniere dun module, mis a part que le seul fait de le decom- 
presser dans le dossier themes/engi nes l’activera spontanement. Le pre- 
mier role du moteur de theme est de permettre une separation entre 
donnees et presentation des donnees, en fournissant au theme toutes les 
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informations dont celui-ci a besoin pour construire une page (titre du 
site, contenus, etc.). En retour, l’autre role du moteur est de comprendre 
la syntaxe utilisee par le theme pour fournir au coeur de Drupal une page 
en XHTML correctement formee. On comprendra alors aisement qu un 
theme developpe pour un moteur ne fonctionnera quavec ce moteur. 

Un theme est un element qui s’installe exactement comme un module, 
mais avec une interface d’administration differente. II est compose de 
ressources (feuilles de style, images, etc.) et dun ensemble de fichiers 
permettant de generer les pages, et il utilise les donnees ainsi que la syn- 
taxe imposees par le moteur de theme. 

Dans la pratique, Drupal est fourni avec un moteur de theme standard 
appele PHPTemplate qui utilise la syntaxe PHP Une large majorite des 
themes que vous pourrez telecharger sur drupal.org utilisent ce moteur, 
aussi c’est lui que nous etudierons par la suite dans ce chapitre. 

Developpeur, Administrateur et Themeur 

Avant de poursuivre sur Installation d un nouveau theme, prenons le 
temps d’examiner quelques points concernant l’organisation et les diffe- 
rents roles d une equipe chargee de mettre en oeuvre un site sous Drupal. 

Drupal peut etre adapte a vos besoins selon trois axes qui correspondent 
a trois types d’utilisateurs avances differents : 

• le developpeur PHP/Drupal dont le role est d’etendre les fonctionna- 
lites de Drupal. II construira ainsi de nouveaux modules pour adapter 
Drupal au plus pres des besoins du projet ; 

• l’infographiste (ou « themeur » dans le vocabulaire drupalien) qui 
developpera fidentite visuelle et fergonomie du site. II sera amene a 
creer un ou plusieurs nouveaux themes pour le site ; 

• Tadministrateur qui gerera Taj out de nouvelles fonctionnalites. Son 
utilisation de Drupal consiste a installer de nouveaux modules ou de 
nouveaux themes, et de les parametrer. 

Le danger classique lors de la realisation d un gros projet avec Drupal est 
de melanger ces roles, soit parce que vous ne disposez pas de toutes les 
competences dans votre equipe, soit parce que la frontiere entre ces trois 
domaines est mal tracee. Le resultat est, par exemple, fobtention d’un 
site contenant des dizaines de modules recuperes sur drupal.org qui 
seraient trop evolues ou mal adaptes au besoin, et tout cela par manque 
de developpeur competent. Ou alors de voir apparaitre des fonctions de 
traitement de finformation propres aux modules se retrouvant dans le 
theme, parce que cette fois nous aurions un infographiste competent 
sous Drupal mais toujours pas de developpeur. 
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Bien evidemment, cette problematique va croissante avec la taille du 
projet, et devient particulierement critique pour un projet visant a cons- 
truire un site a fort trafic. 

Pour bien comprendre et respecter les frontieres entres les trois domaines 
de competence evoques, il est possible de se fonder sur des regies simples. 

• N’activez que les modules que vous utilisez completement et dont 
vous maitrisez le fonctionnement. Mefiez-vous des usines a gaz qui 
font la pluie et le beau temps, alors que vous n auriez besoin que de 
trois gouttes d’eau. Tout est libre dans Drupal, ne vous privez done 
pas d’extraire une fonctionnalite d un gros module pour la coller dans 
un module que vous maitrisez. Votre seule obligation sera de reverser 
le code d un tel nouveau module a la communaute, car tous les projets 
disponibles sur drupal.org sont sous licence GPL v2. 

• Un theme ne doit jamais contenir une requete SQL. Si vous rencontrez 
une situation ou il est necessaire de faire appel a ce genre de solutions, 
cela signifie que vous avez besoin d un module specifique, qu il soit 
developpe par vos soins ou obtenu via la communaute Drupal. Toute- 
fois, une solution degradee peut consister a utiliser le fichier de theme 
tempi ate . php que nous decouvrirons dans ce chapitre. 

• Interdisez-vous de maniere stricte d utiliser la fonctionnalite Drupal 
permettant de mettre du code PHP dans les contenus, que ce soit des 
blocs ou des noeuds. Tout code ajoute de cette maniere sera tres diffi- 
cile a maintenir car il sera stocke dans la base de donnees, et non pas 
dans un fichier PHP comme il se doit. Tracer des anomalies even- 
tuelles dans ces circonstances - surtout lorsque les auteurs ne sont plus 
sur le projet - sera extremement consommateur de temps, et done 
d’argent. Lajout de code PHP ne peut servir que pour la gestion de la 
visibilite des blocs ; veillez alors dans ce cas a ne jamais depasser une 
seule ligne de code (typiquement un « return vrai/faux »), et ne faites 
jamais de requetes SQL. La aussi, une solution degradee consisterait a 
creer une fonction dans le fichier de theme template. php que vous 
pourrez appeler dans le champ de visibilite du bloc. 

Ces avertissements sont le fruit d’experiences multiples et ne sont pas 
limites a Drupal. D’un contexte a l’autre, les pieges de tout projet infor- 
matique restent bien souvent les memes : 

• les compromis que vous faites aujourd’hui par manque de temps 
seront payes au centuple dans la suite de votre projet ; 

• il est illusoire de croire que des mauvais choix sont rattrapables. Une 
fois les mauvaises directions prises, il sera toujours complique et sur- 
tout couteux de revenir en arriere ; 
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• l’economie faite dun developpeur competent en debut de projet se 
paiera plus tard et beaucoup plus cher, lorsque vous aurez besoin de 
faire evoluer votre site ; 

• lorsqu’on demarre un projet informatique, 30 % du temps prevu pour 
le developpement doit etre alloue a la conception, c’est-a-dire au tra- 
vail sur le papier. Ne minimiser jamais cette etape qui est seule 
garante des bons choix ; 

• et n oubliez jamais que le cout final complet d un projet informatique 
se decompose statistiquement en 20 % pour le developpement et la 
mise en oeuvre, et 80 % pour la maintenance et l’exploitation au quoti- 
dien. A vous de deviner oil se trouvent les vrais gisements d economie. 

Ou allons-nous ? 

A partir de maintenant, nous allons sortir du champ theorique pour 
prendre la casquette du deuxieme des trois personnages que nous venons 
d’evoquer : le themeur. Ce qui suit sera par consequent plus technique 
que ce que nous avons pu aborder jusqu’a present. 

Pour une bonne comprehension, il est done necessaire de disposer d’un 
bagage en XHTML, CSS et PHP, qui forment a eux trois les compe- 
tences de base du themeur. 

Nous allons commencer par voir ce que sont concretement des themes 
pour Drupal, et comment les installer, les activer et les parametrer. 

Ensuite, nous allons creer notre propre theme en nous aidant d’un theme 
existant fourni dans Drupal et voir ainsi qu’avec un minimum de con- 
naissances en CSS, PHP et XHTML, nous pouvons deja obtenir une 
apparence radicalement differente. 

Enfin, nous aborderons des techniques plus avancees du theme pour 
entrer ainsi dans les rouages de PHPTemplate. 


Gerer les themes 

L’administration des themes 

Drupal dispose dune serie de six themes standards que vous pouvez 
decouvrir en vous rendant dans radministration des themes ( Administrer > 

Construction du site > Themes). 

Le theme active par defaut que nous utilisons done depuis le debut est 
Garland. Comme pour les modules, vous pouvez activer plusieurs 
themes en meme temps. La difference reside ici dans le fait qu’un seul 
theme peut etre utilise Par defaut. 
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Capture d'ecran 


Horn 


Version Active 


Par 

defaut 


Operations 


Bluemarine 

Theme multicolonnes, 
base sur dee tables, aux 
tons marins etcendres. 


□ O 


Figure 11-2 

Le panneau de configuration des themes 


Figure 11-3 

Selection du theme Bluemarine 


Figure 11-4 

Notre site avec le theme Bluemarine 
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0 'S' configurer 


Le theme par defaut choisi est applique pour tous les visiteurs, et les 
autres themes actives peuvent l’etre mais uniquement par les utilisateurs 
authentifies de votre site a qui vous aurez offert ce droit. 

Nous allons commencer notre visite par ractivation du theme Blue- 
marine. Cochez sa case Active , et son bouton radio Par defaut. 

Bluemarine 

Theme multbobnnes, basesurdes tables, aux tons 6.1 0 0 (§) 

marins etcendres. 

II suffit maintenant de cliquer sur le bouton Enregistrer la configuration 
pour que Tapparence globale du site change immediatement. Faites un 
tour sur la page d’accueil pour mieux en juger. 
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Parameter son theme 


Un theme n est pas qu’une simple apparence, il s’agit d’un simili-module 
disposant de ses caracteristiques propres, et done d une capacite de con- 
figuration. Pour etudier cela, revenons dans fadministration des themes 
et selectionnons a nouveau le theme Garland comme theme par defaut 
avant d’enregistrer ce changement. 

Comme vous le voyez, chaque theme est dote d un lien configurer qui 
apparait lorsqu’ il est active et qui correspond au parametrage specifique 
du theme. En haut de la page et a droite de fonglet Liste, vous apercevez 
un autre lien configurer correspondant cette fois-ci au parametrage pour 
fensemble des themes. 

Nous nous interesserons au parametrage specifique un peu plus tard ; 
concentrons-nous pour finstant sur le parametrage global en cliquant 
sur fonglet Configurer. 

Nous trouvons dans cette page un ensemble de reglages destines a modi- 
fier fapparence des themes. En premier lieu vient une serie de cases a 
cocher controlant faffichage de certaines informations. 

• Logo : il s’agit de l’image qui se trouve en haut a gauche de la page. 
Par defaut, e’est la mascotte de Drupal. Activez cette option qui est 
importante pour l’identite visuelle de notre site, nous verrons un peu 
plus loin comment changer ce logo. 

• Nom du site : e’est le texte « Colchique » qui se trouve a la droite du 
logo. Il parait judicieux de le laisser active. 

• Slogan du site : e’est un message court qui s’affichera dans l’en-tete du 
site. Le slogan est celui que nous avons parametre au chapitre 6, via 
Configuration du site > Informations. A laisser active ou a activer le cas 
echeant. 

• Objectif du site : dans le meme esprit que le slogan et parametrable au 
meme endroit, e’est une phrase qui s’affichera entre l’en-tete de la 
page et le contenu. 

• Portrait des utilisateurs dans les contributions et Portrait des utilisateurs 
dans les commentaires : ce sont la deux options qui permettent au 
theme d’afficher le portrait que chaque utilisateur aura parametre 
dans sa section Mon compte, et ceci que ce soit pour un article ou pour 
un commentaire. Decochez cette option pour les articles car ils sont 
presque tous ecrits par Marine, et cochez-la pour les commentaires. 

• Champ de recherche : le champ de recherche permet aux utilisateurs de 
retrouver facilement des contenus a travers une zone de saisie qui 
s’affichera generalement en haut a droite de la page. Cochez cette 
option (il faut aussi que le module Search soit active !). 


249 


www.frenchpdf.com 


11 - Modifier I’apparence 


Drupal 6 - Concevoir et deployer ses applications 


£ 


Bon A SAVOIR Qu'est-ce qu'un favicon ? 

Un favicon est une icone qui s'affiche a cote de I'URL 
d'un site, dans la barre d'adresse du navigateur, ou a 
cote du titre d'un site dans les marques-pages. 

A I'origine, c'est une idee de Microsoft Internet 
Explorer qui imposait que cette ressource soit 
nommee f avi con . i co et soit au format . i co 
de Microsoft. 

Aujourd'hui, tous les navigateurs le prennent en 
charge, le nom du fichier est libre et I'image peut 
aussi bien etre un PNG qu'un JPG. La taille du 
favicon n'est plus imposee, le navigateur la redi- 
mensionnera selon ses besoins, generalement de 
16x16 a 32 x 32 pixels. Enfin, il est possible 
d'utiliser de la vraie transparence (PNG) dans de 
telles images. 


Figure 11-5 

Parametrage du logo du site 


• Icone de raccourci : plus souvent appelee favicon , il s'agit de l'icone du 
site qui apparaitra dans la barre d'adresse du navigateur ou dans ses 
marques-pages. C'est generalement une bonne idee de laisser cette 
option cochee. 

• Liens primaires et Liens secondaires : il s'agit des deux menus que nous 
avons deja abordes lors des chapitres precedents, et nous pourrions ici 
les rendre invisibles. Bien entendu, laissez ces deux options cochees. 

Dans la section suivante, dans Afficher I'auteur et la date de la contribution 
pour les types , nous pouvons specifier quels types de contenu doivent dis- 
poser d'une ligne indiquant son auteur et sa date de redaction. Dans notre 
cas, ce genre d'information n'a d'interet que pour les contenus de type 
Article et Billet. Nous pouvons done le decocher pour tous les autres types. 

Plus loin apparait la section Para metres du logo. Nous pouvons grace a 
elle remplacer la mascotte de Drupal par I'image de notre choix. Pour 
cela, il faut commencer par decocher l'option Utiliser le logo par defaut. 
Ensuite, deux possibility s'offrent a nous : 

• soit indiquer le chemin vers un logo personnalise (une option que 
nous detaillerons un peu plus loin) ; 

• soit telecharger directement un logo comme nous l'avons fait pour le 
portrait d'un utilisateur. C'est l'option que nous prendrons pour l'ins- 
tant. Pour cela, laissez le champ Chemin vers le logo personnalise vide et 
selectionnez une image de votre choix avec le bouton Parcourir. L'image 
sera enregistree sur le serveur lors de l'enregistrement du formulaire. 


Parametres du logo 

Si cette case est cochee, le logo suivant sera affic he. 

® Utiliser le logo pardefaut 
Cochez si vous voulez que le theme utilbe son logo pardefaut. 

Chemin vers le logo personnalise : 

1 I 

Chemin vers le logo que vous voulez utiliser a h pkee du logo pardefaut. 

Enuoyer le logo : 

| /ho me, 'Vo ran/Doc u me nts/arN u me ral/P rojets/Eyro I le s/ate I ie r/Logo co Ic h iq ue . p nc | P arco u ri r. . . 
Si vous n'avez pas un acoes direct aux fbhiers sur le serveur, utilisez ce champ po u r tiansfe ie r votre logo. 


La section suivante concerne le favicon, et fonctionne suivant la meme 
logique que celle traitant du logo. Si vous disposez deja d'une telle icone, 
vous pouvez proceder de la meme maniere pour la selectionner. 

Le parametrage de base etant maintenant termine, nous pouvons sauve- 
garder pour juger du resultat. 
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Colchique , car chaque brin d'herbe est unique... w 

V 1 


Etat du niarc he de ['em pi of pour les Administrate urs rdsea ux 

dm, a&UfiOtiB- 10:3Q — Marine 

Chore her ctnns ee silt . 

[ 1 

Recherche 


Figure 11-6 Un sympathique logo, n'est-ce pas ? 


Nous voyons ici que le logo a change, que le slogan est apparu a droite 
du titre du site et qu un champ de recherche est a present visible. De 
meme, l’avatar de Marine est egalement visible dans ses commentaires. 


Merci a vous., je vais encore 

Menci a vous, je vais encore un peu I'ameliorer... 
supprimer editer repondre 


mar, QSm2Q09 -11:47 — Marine 



Figure 11-7 

Les portraits des utilisateurs enfin en action 


Parametrages par theme 

Parametrages specifiques d’un theme 

Avant de poursuivre, il est important de retenir que tous ces reglages 
sont soumis a Interpretation de hauteur du theme. Par exemple, le 
slogan qui est a droite du titre dans le theme Garland sera en dessous du 
titre avec le theme Marvin. De meme, les liens primaires peuvent 
changer de place en fonction des choix du createur du theme. 

Par ailleurs, certains themes plus evolues comme Garland disposent de 
possibilites de parametrage supplementaires au tronc commun de Drupal. 

Nous trouvons done ici l’usage du lien configurer specifique a chaque 
theme, dont nous avions constate la presence precedemment. Pour bien 
comprendre les possibilites qu il offre, retournons sur le panneau d’admi- 
nistration des themes et cliquons sur le lien configurer de Garland. 

Sur la page qui s’affiche, nous constatons tout d’abord que la fin du for- 
mulaire contient les memes informations que la configuration generale. 

Nous en deduisons qu il est possible de redefinir pour chacun des themes 
les valeurs par defaut que nous avions precedemment choisies. 

Nous constatons aussi que le debut du formulaire contient une nouvelle 
et imposante section Schema de couleurs. Il s’agit la dun parametrage 
propre a Garland que vous ne retrouverez pas sur tous les themes. 
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Figure 11-8 

La selection des couleurs du theme Garland 


Figure 11-9 

Le theme Garland en mode Olive 
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Garland - Fluid Width 
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Grace a cette nouvelle section, nous pourrons modifier l’ambiance com- 
plete de Garland. La liste )eu de couleurs vous permet de choisir un profil 
predefini de coloris, et les champs suivants de regler specifiquement 
chaque teinte a votre convenance. Lorsque la selection de couleurs vous 
convient, il suffit de sauvegarder pour juger du resultat. 
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Parametrage des blocs par theme 

Pour un theme donne, d’autres possibilites de parametrage existent et 
s’averent plus epineuses a manipuler : elles concernent notamment les 
regions, notions que nous avons etudiees au chapitre precedent, et qui se 
presentent differemment suivant le theme selectionne. 

En effet, si nous retrouvons des regions classiques comme Barre de gauche 
et Barre de droite quels que soient les themes, elle n ont pas forcement le 
meme nom et leur liste n est pas toujours la meme d un theme a l’autre. 

Par exemple, si vous activez le theme Marvin, vous constaterez en allant 
dans la page d’administration des blocs que vous ne disposez pas de region 
En-tete ni de Pied de page. En activant ce theme, vous serez ainsi sans 
doute surpris de voir notre ligne d ’informations legales et notre avertisse- 
ment a l’administrateur apparaitre brutalement sur la barre de gauche. 


Colchique 

, car chaque brin d'herbe est unique... 

Contactez nous | Deconnectez-vous 
Nos Publications | Les Billets | FAQ 



Attention !!! Vous etes 

ADMINISTRATEUR 


Etat du marche de I'emploi p 

© Colchique Conseil - Tout 

droits reserves - Ce site est 
propulse par Drupal 

Les administrateurs reseaux conn; 

Figure 11-10 

Par Marine le 06/14/2009 - 10:30 Reel , ... 

Les mouvements de blocs avec le theme Marvin 


II n’y a cependant rien d’etonnant a cela : ayant un bloc active pour une 
region qui n’existe pas, Drupal a choisi de le deplacer sur la premiere 
region disponible. 

II faut done partir du principe que chaque theme dispose de ses propres 
regions. Nous pouvons confirmer ce fait en allant dans le panneau 
d’administration des blocs. 


Bloc 1 

Region 

Operations 

Barre de gauche 



Avertissement 

Barre de gauche C 

configurer supprimer 

Pied de page du site 

Barre de gauche 

configurer supprimer 

Barre de droite 


Barre de droite 

<aucun> 


tf Selecteur de langue 

Barre de droite 0 

configurer 


Figure 11-11 

Le theme Marvin a un nombre tres restreint de regions. 
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Avec ce theme, nous n avons que deux regions, ce qui explique la migra- 
tion de nos deux blocs. 

La localisation variable des regions selon le theme peut s’averer tres vite 
genante, si vous avez, par exemple, plusieurs themes pour votre site dont 
vous laissez le choix d’activation a vos utilisateurs. Pour repondre a cette 
problematique, vous avez fort heureusement la possibility de definir la 
disposition de blocs pour chacun de ces themes. 

Par defaut, lorsque vous arrivez sur fadministration des blocs, vous tra- 
vaillez sur la configuration de bloc du theme courant. Nous avons done 
depuis le debut travaille sur la configuration du theme Garland. En acti- 
vant un nouveau theme, et surtout en le positionnant comme theme par 
defaut, nous avons implicitement recopie la configuration de bloc de 
Garland vers Bluemarine, avant de le faire pour Marvin avec le deplace- 
ment de certains blocs comme nous favons vu. 

II est aussi possible de modifier chacun des themes actifs sans avoir a les 
mettre successivement par defaut. Pour cela, vous noterez que sous les 
onglets Liste et Ajouter un bloc se trouve une liste de sous-onglets, un par 
theme active. 


Figure 11-12 

La disposition des blocs peut 
etre specifique a un theme. 


Blocs 

Liste Ajouter un bloc 

Marvin Bleu marine Garland 


Modules magiques 

Faire un site pour mobiles ? Tres simple ! 

Cette notion de parametrage specifique des blocs 
peut etre tres facilement mise en application si vous 
desirez rendre votre site compatible avec les unites 
mobiles (telephones Android, iPhone et iPod, Black- 
berries, etc.). II vous suffit pour cela de disposer de 
deux themes, I'un pour les ordinateurs de bureau, 
I'autre pour les petits ecrans, et de configurer une 
absence de blocs de par et d'autre du contenu pour 
le theme Mobile. Ensuite, vous n'avez plus qu'a ins- 
taller le module Mobile Tools. Une fois active, ce 
module vous permet de selectionner un theme diffe- 
rent du theme par defaut, soit pour une URL donnee 
(par exemple, http://mobile.colchique-conseil.fr), 
soit pour la meme URL mais en identifiant le client 
comme etant un mobile. 

► http://drupal.org/projetc/mobile_tools 


Vous pouvez done cliquer sur un autre theme, et ainsi retrouver l’appa- 
rence et la configuration de bloc du theme selectionne pour en faire le 
parametrage. II est egalement possible de desactiver certains blocs par 
theme, une fonction qui complete tres bien le parametrage de visibility 
de chaque bloc. 

Installer un nouveau theme 

Apres avoir bien explore les themes fournis en standard avec Drupal, il 
est maintenant grand temps d’en installer de nouveaux. Cette operation 
s’effectue de la meme maniere que pour un module. 

II nous faut tout d’abord choisir un theme sur le site drupal.org, notre 
point d’entree etant toujours la page des telechargements de ressources, 
http://drupal.org/project. Une fois arrive sur cette page, cliquez sur Themes. 

Vous pouvez y choisir un theme en ayant une idee du resultat final grace 
a Fapercpi qui faccompagne. Ici, nous avons par exemple le theme 
Acquia Marina. 
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Acquia Marina 


By jwolf on the 1st of October, 2008 


q* h-dc; :■ 'm 


Acquia Marina is an advanced theme developed by TopNotchThemes in 
partnership with Acquia for their commercially-supported Drupal 
distribution. It contains the same kinds of features you'll find in our other 
Drupal themes. 

Features 



* 1, 2, or 3 column layout 

* 15 collapsible block regions 

* Drop-down primary links menu (optional) 

* Advanced theme settings to customize without coding! 

* Includes icons for core and Views blocks 

* High attention to detail on things like forms, lists, comments, quotes, and Drupal maintenance page 
+ Cross-browser tested in IE6/7, Opera, Safari, and Firefox 

* Layered Photoshop PSD files now available! 


This theme is also available in Acquia Drupal. 


Show your support for this theme, get additional help, show off your site, and discuss with other users 
-join our group! 


Version Date Links Status 

6.X-1.5 2Q08-Dec-22 Download ■ Release notes Recommended for 6.x y 

Find out more Bugs and feature requests 


Figure 11-13 

La page de projet 
du theme Acquia Marina 


Une fois le theme selectionne, verifiez qu’il existe bien pour la version de 
Drupal que vous utilisez : regardez dans la zone des telechargements du 
theme et identifiez une version, par exemple 6.x pour un Drupal 6. 
Comme pour les modules, privilegiez les versions stables en vert. L’utili- 
sation d un theme non stable (en rouge) est cependant beaucoup moins 
risquee que celle d’un module. 

Lorsque vous disposez de la bonne version, cliquez sur le lien Download 
pour telecharger l’archive du theme au format tar .gz. 

Comme pour les modules, nous allons decompresser notre theme dans le 
dossier sites, mais cette fois-ci dans le sous-dossier si tes/al 1 /themes/ 
contri b. 

Ceci fait, vous pouvez retourner dans fadministration des themes oil 
vous devriez voir apparaitre votre ajout. 


Acquia Marina 




TopNotchTbem 


9 


Acquia's Marina theme is 
ideal for blogs and 
community sites. Includes 
advanced theme settings 
and 15 flexible content 
regions for a variety of 
layouts. By 
TopNotchThemes 


6.x- 1.9 


0 


* 


Figure 11-14 

Activation du theme Acquia Marina 
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II ne reste alors plus qua activer ce theme, le selectionner Par clefaut et 
Enregistrer la configuration pour faire disparaitre le theme Marvin. 

Pour observer le rendu de maniere plus complete que sur la page de con- 
figuration des themes, retournons a la page d’accueil. 



Colchique 

Car chaque brin d'herbe est unique.. 


Recherche 


CONTACTEZ NOUS D BOON N ECTEZ-VOUS 



ftp CE QUI S'EST DIT.» 


ETAT DU MARCHE DE L'EMPLOI POUR LES ADMINISTR ATEURS RESEAUX 

Posted dim, 06/ 14/2009 - 10:30 by Marine 


» Merci a vo us, je vais encore 
il y a 2 semaines 2 heures 
» Article passionnant mais 

il y a 2 semaines 2 heures 


ADMINISTRATEUR 


Les aciministrateurs reseaux connaissentt-ils lacrise ? 

Ajo uter no commentaire 

ETAT DU MARCHE DE L'EMPLOI POUR LES INGENIEURS INFORMATICIENS 

Posted dim, 06/14/2009 - 10:23 by Marine 
La arise touche t-elie les informatieiens ? 


» Moncompte 
» My relationships 
» Translate strings 
» Greer un con ten u 
» Administer 
» Se deconnecter 


Ajo Liter un CDniinenlaure 


UN NOUVEL ARTICLE 

Posted ven, 06/05/2009 - 16:20 by Marine 
Corps de I'article... 


Aju uter un commentaire 


Figure 11-15 Notre site pare du tres sympathique theme Acquia Marina 


Nous constatons encore une fois que nos blocs ne sont plus a la meme 
place. Cette fois-ci, cela s’explique par le fait que dans ce theme, les 
regions pour les colonnes n ont pas les memes noms que dans le theme 
Garland. Nos blocs de droite ont done ete deplaces vers la region sidebar 
first. Comme ce theme ne dispose pas d une veritable colonne de droite, 
nous allons les y laisser. 

Enfin, comme pour Garland, ce theme dispose de parametrages specifi- 
ques tres etoffes que vous pouvez explorer. 

A vous maintenant de faire votre marche et de trouver le theme qui vous 
convient le mieux. Et si aucun ne vous satisfait, nous verrons bientot 
comment creer le votre. 
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Changer les pages d’erreur 

Avant de nous lancer dans le developpement d’un theme personnel, 
voyons d’abord comment regler les derniers aspects visuels qu’il nous est 
encore possible de modifier via la simple administration. 

L’un de ces aspects visuels correspond aux pages d’erreur que Drupal 
affiche lorsqu’un document est introuvable (erreur 404) ou quand un 
document n’est pas accessible avec le role de l’utilisateur (erreur 403). 


BonAsavoir 404/403, qu'est-ce done ? 

A chaque fois qu'un navigateur affiche une page, il effectue une 
requete sur un service HTTP. Le service analyse la requete et fournit une 
reponse au navigateur. Dans cette reponse se trouve un code de statut 
qui permet de savoir si tout s'est bien passe ou pas. 

Le statut renvoye est sur trois chiffres, le premier indiquant la categorie 
dans laquelle se trouve la reponse : 

• 1XX : ce statut indique une information ; 

• 2 XX : ce statut indique un succes. Ainsi, toute page renvoyee avec 
succes est accompagnee du statut 200 OK ; 

• 3XX : ce statut indique que le navigateur doit aller chercher ailleurs sa 
reponse (redirection). Ainsi, le statut 301 Moved Permanently indique 
que la page a change d'adresse et que la nouvelle adresse est plus 
loin dans la reponse ; 

• 4 XX : ce statut indique qu f il y a eu un probleme. 404 Not Found cor- 
respond a une page qui n'existe pas, 403 Forbidden indique quant lui 
que le navigateur n f a pas le droit de la visualiser ; 

• 5 XX : ce statut indique aussi un probleme mais generalement beau- 
coup plus grave, avec le classique 500 Internet Server Error qui 
correspond generalement a un plantage sur le service HTTP lui-meme. 
C f est typiquement ce que renverra Apache si vous vous trompez dans 
la syntaxe d'un fichier .htaccess. 


Lorsqu’une telle erreur est detectee, Drupal fabrique une page generique 
ressemblant a ceci : 


Page non trouvee 

La page demandee n'a pu etre trouvee. Figure 11-16 

Le message standard de Drupal pour une page non trouvee 


Si ces pages telles qu’elles sont generees par Drupal ne vous conviennent 
pas, vous avez la possibilite d’y substituer n’importe quel contenu, de 
preference de type Page. Pour tester cela, creons un contenu Page avec 
un message specifique pour une erreur 404. 
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Figure 11-17 

Creation d'une page 404 personnalisee 


Figure 11-18 

Changement des chemins 
pour les pages d'erreur 403 et 404 


Module magique 

Des blocs sur les pages d'erreur 

Vous aurez remarque que les pages d'erreur 403 et 
404 sont depouillees de leur bloc, et ceci avant 
tout pour des raisons de performance. 

Si vous avez cependant besoin de blocs dans ces 
pages, vous pouvez utiliser le module 404 Blocks. 

► http://drupal.org/project/blocks404 


Figure 11-19 

Notre nouveau message d'erreur 
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Greer ’Page’ 

Titl e : * 

[Ooops ; cette page n'existe pas.., 

► Parametres <lu menu 


Corps : 

I Desole, mais la page que vous demandez n'existe pas. . . | 


Un fois cette page enregistree, notez le permalien - ici node/17 et 
faites ensuite de meme pour une page d'erreur « acces interdit », qui aura 
alors comme permalien node/18. 

Ceci etant fait, allez dans la configuration du site, puis dans Rapports 
d'erreur. Vous avez la deux champs dans lesquels vous pouvez saisir les 
deux alias avant d’enregistrer l’ensemble. 

Rapports d’erreur 

Page 403 par defaut (acces refuse) : 

http7Aftww.colchique-cQnseil.fry [nQde/18 j 

Cette page est affichee quand un utilisateur se voit refuser I'acces a une contribution. Si vous ne savez pas quoi mettre, laisser ce champ vide. 

Page 404 par defaut (page non trouvee) : 

http://vwwv.colchique-conseil.fr/ |node/T7| j 

Cette page est affichee quand aucun autre contenu ne correspond au document recherche. Si vous ne savez pas quoi mettre, ne specifies Men. 


Pour verifier que cela fonctionne, saisissez un chemin errone - par 
exemple http://www.colchique-conseil.fr/pas_bon. 

VOIR MODIFIER 

Ooops, cette page n'existe pas... 

Posted dim, 06i'07f2009 - 15:30 by administrateur 

Desole, rnais la page que vous demandez n'existe pas... 


Regler le theme d’administration 

Si vous avez pour objectif de concevoir ou de faire concevoir un theme 
tres graphique, il se peut que celui-ci se revele inutilisable d un point de 
vue ergonomique pour l’administration du site, a moins d’y investir du 
temps et/ou un budget consequent pour le rendre facilement exploitable. 

C’est la raison pour laquelle Drupal vous propose la possibility de definir 
un theme specifique pour la section Administration. Dans ce cas, des que 
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vous entrerez dans le menu Administrer, vous constaterez que votre 
theme est remplace par un autre plus exploitable, typiquement Garland. 

Le choix de ce theme se fait en allant dans la Configuration du site , puis 
Theme d'administration. 

Theme de ^administration 

Theme de I'administration : 

| Garland C | 

Chaisi le theme que les pages d'administration utilisent. Si vous choisissez "Theme par defaut du systeme" 

0 Utiliser le theme d'administration pour les formulates de modification du contenu 

Utiliser le theme d'administration lors de la modification de contenus assistants du lars de leur creation 

1 Enregistrer la configuration || Retablir par defaut | 


Figure 11-20 

Reglage du theme d'administration 


Ici, vous pouvez non seulement changer le theme a utiliser (Garland 
reste un bon choix), mais imposer egalement ce theme lors de l’edition 
dun contenu, ce qui est la aussi une bonne idee. 

Notez qu’il y a une exception a ce reglage : la page d’administration des 
blocs qui, comme nous l’avons vu, utilise le theme que Ton cherche a 
parametrer. 


Modules magiques Des themes specialises 
pour I'administration 

II existe sur drupal.org de nombreux themes 
dedies a I'administration. Citons dans cette cate- 
gorie le magnifique RootCandy declinable aux 
coloris de votre choix (comme Garland). 

► http://drupal.org/project/rootcandy 


Creer son propre theme 

Notre premier niveau d’apprentissage des themes de Drupal est acheve et 
nous savons maintenant les telecharger, les installer et les parametrer. Mais il 
est rare que nous puissions nous arreter la. Chaque site web a sa propre per- 
sonnalite et le theme en est le reflet. Nous allons done a present apprendre a 
creer notre premier theme, de maniere douce, e’est-a-dire en partant d un 
theme existant que nous adapterons progressivement a nos besoins. 

Qu’cst-ce qu’un modele ? 

A son origine, PHPTemplate n’etait qu un moteur de theme parmi 
d’autres et il n’a ete ajoute a Installation standard de Drupal qu a partir 
de la version 4.7. A la version 5.0, il a ete integre encore plus profonde- 
ment dans le coeur du CMS. Aujourd’hui, meme s’il est toujours possible 
d’utiliser d’autres moteurs pour des besoins specifiques (de compatibility 
avec d’autres CMS, par exemple), PHPTemplate reste le passage oblige 
d’un theme sous Drupal. 

Le succes de PHPTemplate (qu’on peut traduire litteralement par 
« modele PHP ») tient avant tout a sa souplesse et a sa rapidite de mise 
en oeuvre. En effet, l’approche minimale requiert seulement quatre 
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fichiers que Ton appelle des modeles (ou templates en anglais) pour trans- 
former l’apparence de tout un site. 

Les modeles sont des fichiers portant l’extension . tpl . php et stockes a la 
racine du theme. Leur role est de produire le rendu visuel soit d un ele- 
ment specifique de la page (un commentaire, un bloc ou un noeud), soit 
de la page elle-meme. Leur contenu est un melange de code XHTML 
pour la mise en forme, et de code PHP pour l’insertion des donnees a 
presenter. Ainsi, lorsque PHPTemplate utilise un modele, il en resulte la 
production d un fragment de code XHTML. Les balises de ce code dis- 
poseront de classes et d’identifiants CSS definis par le themeur pour 
permettre a une ou plusieurs feuilles de style incluses dans le theme 
d’operer la presentation finale (couleurs, images, bordures, etc.). Enfin, 
des comportements ecrits en JavaScript peuvent venir completer l’appa- 
rence et l’ergonomie resultant des modeles (onglets dynamiques, menus 
deroulants, effets, etc.). 

PHPTemplate fournit les donnees au modele par l’intermediaire de 
variables PHP. Chaque modele dispose ainsi d un jeu de variables speci- 
fiques au travail a realiser. Le themeur n a plus qua utiliser ces variables 
grace a du code PHP insere au sein de sa mise en forme XHTML. 

A titre d’exemple, le modele qui permet de mettre en forme un com- 
mentaire s’appelle comment. tpl .php. Pour chaque commentaire a for- 
mater, PHPTemplate lui fournit un jeu de variables comme $ content, 
qui contient le texte du commentaire a formater, ou encore $submitted, 
qui contient le nom de hauteur et la date d’envoi de ce commentaire. 
Une fois realise, le modele pourrait avoir la forme suivante. 

Un exemple de modele pour les commentates 

<div cl ass="commentai re M > 

<div cl ass="auteur"><?php print Ssubmitted; ?></div> 

<div cl ass="content"> 

<?php print $content; ?> 

</di v> 

</di v> 

Le jeu destructions PHP utilisables dans un modele n est pas limite, et 
c’est la que reside le danger de cette approche. II est en effet possible 
d ’inserer dans ce type de modele un code PHP complexe, avec par 
exemple des requetes a la base de donnees. Cette pratique est fortement 
deconseillee. Si vous ressentez la necessite d’ecrire un code complexe, la 
raison probable est que PHPTemplate ne vous a pas fourni la variable 
dont vous aviez besoin. Dans ce cas, reportez-vous a la fin du chapitre 
pour decouvrir la bonne maniere d’etendre un modele en y ajoutant vos 
propres variables. 
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Le code PHP d’un modele doit rester extremement simple et ne con- 
tenir que deux types destruction : print pour inserer le contenu dune 
variable, et eventuellement i f/el se pour implementer des conditions. 

Attention aussi a la forme courte de la balise PHP <? qui nest pas 
reconnue par de nombreux serveurs. Utilisez toujours sa version longue 
<?php. Pour les memes raisons, utilisez toujours <?php print $variable 
?> et evitez a tout prix sa version courte <?= $vari abl e ?>. A elles seules, 
ces deux regies vous eviteront enormement de problemes lors dune mise 
en production. 

L’imbrication des modeles 

Comme nous l’avons dit plus haut, quatre modeles au minimum per- 
mettent de mettre en forme l’ensemble dun site Drupal : node.tpl .php, 
comment .tpl . php, block. tpl . php et page . tpl . php. Pour mieux com- 
prendre comment ces quatre modeles fonctionnent, prenons comme 
exemple un theme simple comme Bluemarine. 


t L 


page.tpl .php 


Colohique 


Can chixqtis JMi dheibi* &Sf uiutjue^. 


J ACCuelt 


Blenvenue 

Voir Modifier Revisions 


Rscriirlement 

Biem/enue sur le- sile de Cotchique Conaeil 

le cabinet de censeil en ress ounces Surname qui a I'etfiAque a coeur 

Vous tnouverK sur none srte une presentation complete de la societe, de ses intervenantei de sea vaiei« vous pourrez aussi y 
decDuyrirroa publications amai que nas billets, dbumeur 

Bonne visile 

liequlpe doftrtp^ivrwwxQichiqLe-r.onseiut 
Fichier attache I alio 

copie d'ecr-an.fmg L05.4K® 

Mainsel ufilisate li \pdf 274.03 Ko 
Ajouter Lit common taire 



Article passiannant mais 

Article passlonnantmms manquanl neanmoms un peu desubslabce 


* ] comment. tpl. php 


l ► Mon compie 
* ► Greet un cottefiu 
J a Se deconnoeteir 


| j j Merci a vqljs, je vais encore 

| | Uerci a irau s, | e vai s en care un peu I'ameliciner .. 


:: f comment. tpl.php~t 

t I 


- I block.tBLphpJ 


J ! S C6l« hiqli* Cam *11 -T6W diailt rftt ivA - Cult* vtl plipuK* p*| di i*:hI 


Figure 11-21 

La responsabilite des modeles 
dans la construction d'une page 


Pour construire cette page, PHPTemplate utilise les quatre modeles en 
les imbriquant les uns dans les autres. 


www.frenchpdf.com 


261 


11 - Modifier I’apparence 



Drupal 6 - Concevoir et deployer ses applications 


£ 


• En tout premier lieu est utilise le modele node.tpl.php. PHPTemplate 
lui fournit par l’intermediaire d un jeu de variables specifiques tout le 
contenu du noeud a mettre en forme (titre, corps, etc.). II recupere ainsi 
une version du contenu mise en forme en XHTML. 

• PHPTemplate effectue la meme operation, mais cette fois avec 
chacun des commentaires du noeud en utilisant le modele 
comment. tpl .php. En retour, PHPTemplate dispose dune liste de 
commentaires formates en XHTML qu’il ajoute au rendu XHTML 
du noeud. 

• Ensuite, PHPTemplate va proceder au rendu XHTML de chacune 
des regions du theme. II constitue pour cela une liste de blocs visibles 
par region pour la page et utilise pour chacun d’eux le modele 
bl oc . tpl . php. 

• Derniere etape, PHPTemplate fournit au modele de la page, 
page. tpl .php, le rendu XHTML du noeud et de ses commentaires, 
et celui de chacune des regions. Le modele de page lui renvoie alors 
un document XHTML complet et pret a etre renvoye par Drupal au 
navigateur web. 

Le modele Page est, vous l’aurez compris, le garant de la structure 
visuelle du site. C’est en effet lui qui determine la disposition de chacune 
des regions dans le document XHTML final. 

Creation d’un theme personnalisable 

Pour passer de la theorie a la pratique, le plus simple est de demarrer en 
effectuant des modifications a partir dun theme existant, par exemple le 
tres basique theme Bluemarine disponible dans le dossier themes/ 
bl uemari ne. 

Commen^ons par regarder ce que nous trouvons dans ce dossier : 


Figure 11-22 

L'arborescence et le contenu d'un theme 


i themes 


I bluemarine 


’# block. tpl. php 
H bluemarine. info 
'& comment. tpl. php 
3 logo, png 
>' node.tpl.php 

8 page.tpl.php 

9 screenshot, png 
style.css 

“ ,w style-rtl.css 
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Comme vous le voyez, un theme est finalement un simple dossier conte- 
nant les types de fichiers suivants : 
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• des modeles portant l’extension .tpl .php et presents a la racine du 
theme, charges de produire la mise en forme XHTML des donnees 
fournies par PHPTemplate a chacun d’eux. Comme nous l’avons vu 
precedemment, ils sont au nombre minimum de quatre : 
block. tpl . php, node . tpl .php, comment. tpl .php et page. tpl .php ; 

• un ou plusieurs fichiers CSS pour styler la presentation XHTML. 
Par defaut, PHPTemplate utilise pour cela le fichier style. css a la 
racine du theme. Le fichier style- rtl .css est quant a lui utilise en 
plus de style. css lorsque Drupal doit afficher une langue dont 
l’ecriture se fait de droite a gauche (rtl signifiant right to left) ; 

• eventuellement, un ou plusieurs fichiers JavaScript pour ajouter une 
couche comportementale. Par defaut, PHPTemplate utilise, s’il 
existe, le fichier script, js a la racine du theme. Pour ce theme tres 
simple, nous n’avons aucun comportement JavaScript a ajouter ; 

• des ressources graphiques (images, polices, etc.) generalement utili- 
sees par les feuilles de style ; 

• un fichier portant le nom du theme (qui est aussi le nom du dossier 
du theme) et fextension .info, contenant toutes les informations 
descriptives de ce theme. 

La premiere etape consiste a dupliquer ce theme, qui se trouve dans le dos- 
sier themes/bl uemari ne, vers un nouveau dossier si tes/al 1 /themes/ 
mes_themes, et a le renommer en mon_theme. Attention, ne commettez 
jamais lerreur de modifier directement un theme (ou nimporte quel autre 
fichier standard) de Drupal. Vous vous exposeriez alors a de serieux maux 
de crane lorsque viendra le temps de mettre a jour votre installation. 

Ensuite, afin d’eviter toute confusion avec le theme d’origine, renommez 
le fichier bl uemari ne . i nfo en mon_theme . i nfo, puis ouvrez le fichier avec 
l’editeur de texte de votre choix (gedit, Notepad, etc.) pour en modifier 
le contenu. 

Comme nous le disions plus haut, le fichier .info est la carte d’identite 
du theme. Sa syntaxe se compose dune succession de couples 
variable = valeur avec eventuellement des lignes de commentaire pre- 
cedees du caractere ; . 


Themes magiques Les starter kits 

Le theme Bluemarine a le merite d'etre fourni en 
standard avec Drupal. C'est pour cette raison que 
nous allons I'utiliser comme base de notre appren- 
tissage pour la personnalisation d'un theme. 

Pour la conception d'un theme reel, il existe de 
nombreux themes appeles « starters » (themes 
de demarrage). Ces themes n'ont aucune identite 
visuelle particuliere et sont congus dans le but 
unique d'etre adaptes a vos besoins. Une liste a 
peu pres exhaustive de ces themes de demarrage 
est disponible a cette adresse : 

► http://www.chapterthree.com/blog/ 
squiggy_rubio/ 

review_drupal_6_starter_themes 
Notez que le theme Zen, souvent cite, est loin 
d'etre le plus simple a utiliser. Pour debuter, pre- 
ferez-lui un theme plus simple comme Basic. 

► http://drupal.org/project/basic 


2; $ld: bluemarine . inf o, v 1.4 2007/06/08 05:50:57 dries Exp $ 

3name = Bluemarine 

4description = Table-based multi-column theme with a marine and ash color scheme. 

Sversion = VERSION 

Score = 6.x 

7engine = phptemplate 

8 

9; Information added by drupal.org packaging script on 2OO9-05-13 
lOversion = "6. 12" 
llproject = "drupal" 

12datestamp = " 1242243950" 

13 


Figure 11-23 

Extrait du fichier monjtheme.info 
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Commencez par supprimer tout ce qui se trouve apres la ligne 8, et pre- 
nons chaque entree une a une. 

• Le champ name definit le nom en clair du theme. Notez que le nom 
Drupal du theme est celui donne par le fichier . i nfo. Nous saisirons 
done ici un nom facilement lisible comme Mon Theme, tandis que 
Drupal utilisera quant a lui le nom interne mon_theme. 

• Le champ descri pti on est un texte d’aide destine a etre affiche dans le 
panneau de configuration des themes. Saisissez par exemple Ma versi on 
modifiee du theme BlueMarine pour le site Col chi que-Consei 1 . 

• Le champ version est mal renseigne dans le theme d’origine, nous 
allons changer cela en rempla 9 ant la valeur VERSION par 1.0. C’est le 
numero de version de notre theme, qui a une valeur consultative et 
informative. 

• Le champ core est lui plus important car il indique dans quelle ver- 
sion de Drupal ce theme est cense fonctionner. Avec 6 . x, nous indi- 
quons que ce theme fonctionnera avec tous les Drupal version 6. En 
effet, Drupal fonctionne pour les themes suivant la meme logique 
que pour les modules, et ne cherche jamais a garder une compatibilite 
ascendante. Ce parametre permet done d’eviter d utiliser des themes 
non compatibles avec la version de Drupal mise en oeuvre. 

• Le champ engine nous ramene a la conversation precedente. Ce 
champ permet de definir quel moteur de theme est utilisable pour ce 
theme. Ici il s’agit done bien de PHPTemplate. 

Une fois modifie, le fichier mon_theme . i nfo doit ressembler a ceci : 

Fichier mon_theme.info 

name = Mon Theme 

description = Ma version modifiee du theme BlueMarine pour le 

site Col chi que-Consei 1 

version = 1.0 

core = 6.x 

engine = phptemplate 

Apres favoir enregistre, retournons dans la configuration des themes 
pour factiver. 


Figure 11-24 

Activation de notre premier theme 



Mon Theme 

Ma version modifiee du theme BlueMarine pour le site 
Colchique-Conseil 


IZI 
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Voila, c est aussi simple que cela. Nous disposons a present d un theme bien 
a nous que nous pourrons personnaliser sans risque pour le reste du systeme. 
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Utiliser les feuilles de style 

Comme nous l’avons vu, les modeles d’un theme utilisent un melange de 
code PHP pour inserer les donnees, et de code XHTML pour leur mise 
en page. Les balises XHTML sont, quant a elles, dotees de classes et 
d’identifiants CSS permettant d’en modifier fapparence sur le naviga- 
teur. Le premier degre de modification de notre theme consistera done a 
exploiter les styles CSS pour changer autant de choses que possible. 

Par defaut, PHPTemplate detecte automatiquement la presence dans le 
dossier du theme de la feuille de style style. css. De maniere generale, 
vous n avez jamais besoin de lier vous-meme une feuille de style a une 
page. Ces taches sont prises en charge directement par PHPTemplate. 

S’agissant d un theme qui n a pas ete ecrit par nos soins, il sera difficile 
de savoir quels identifiants ou quelles classes CSS ont ete utilises pour 
modifier le style d une balise. Pour pallier cette meconnaissance, nous 
allons utiliser un outil absolument vital, une extension pour Mozilla 
Firefox nommee Firebug. Firebug permet, entre autres choses, de 
decouvrir tres facilement les identifiants CSS en cli quant simplement 
sur un element de la page. 

Une fois Firebug installe et Firefox redemarre, vous devriez voir appa- 
raitre une icone en forme d ’insecte dans la barre de statut du navigateur 
(voir ci-contre). Cliquez dessus pour faire apparaitre le panneau Firebug. 

Dans la barre d’outils de ce panneau se trouve un bouton Inspecter que 
nous ne cesserons d utiliser dans les travaux a venir. Une fois que Ton a 
clique dessus, il permet d’afficher dynamiquement le code HTML de 
l’element que votre souris survole, ainsi que les sections des feuilles de 
style qui en determinent fapparence. 

Si nous voulons modifier la couleur de fond de f en-tete, nous apprenons 
ainsi que cette zone est geree par une table qui a pour identifiant 
#header, et que cet identifiant est defini dans la feuille de style styl e . css 
a la ligne 80 avec un fond bleu (background-color: #6699CC). 

Nous allons done modifier le fichier style. css pour changer cette cou- 
leur bleue en un fond image de type degrade. Pour creer ce fond, nous 
utiliserons un outil d’edition damages comme Gimp, Inkscape, ou 
encore Adobe Photoshop. 


URL Firebug 

► https://addons.mozilla.org/fr/firefox/addon/ 
1843 



Figure 11-25 

Icone de Firebug 
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Figure 11-26 Apergj du panneau Firebug en action 


Figure 11-27 

L'en-tete vue par Firebug 


tnspecter Editer hi. site-name td#logo tr tbody [^~ 

HTML I CSS Script DOM Ress Style Appaienee 


Console 


/I 999/ah tm I" aml:lang='Tr" dir="lu"> 

E <head> 

□ <body cla.'K="admin-mcnu" sly le="border- 
bottom: Opa nonc;"> 

B -Stable id="he!ider" cellKpuein i e="0" cellpudc 
□ <tbody> 

□ <trt> 

H <td jd="Logo'^ 

I - I I >7 


#beader [ 

backe round-color: 


# header. #content { 
width: lOO tf- 


table { 

fon t-size: 


l as 

com Options v 

style.css?Y{ligne 80) 

#6699CC; 


style, css?Y {ligne 77) 


style.css ? Y { lig ne 55) 


Une fois cette image generee, elle devra etre placee dans un dossier 
mon_theme/images/fond_header . png. A nous de modifier en conse- 
quence la feuille de style styl e . css a la position indiquee par Firebug : 

Portion de style.css a modifier pour le theme de l'en-tete 

#header { 

background-color: black; 

background-image: url ("images/fond_header . png") ; 

height: 79px; 

} 
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Apres un rafraichissement de la page sur le navigateur, nous pouvons 
juger du resultat. 



Colchique 

Car cheque hrin d'herhe est unique... 


Nos Publications | Les Billets | FAQ 

Contactez nous 


Etat du marche de I'emploi pour les Administrateurs 
reseaux 

Soumis par Marine le dim, 06i'14i'2009 - 10:30 
Recrutement Systemes et reseaux 

Les administrateurs reseaux connaissentt-ils la crise ? 


Qui sommes-nous ? 

Colchique est une societe de 
conseil en management specialise 
dans les ressources humaines 
dans le domaine des technologies 
de I'information... 


Figure 11-28 

Notre theme 


» Ajouter un commentaire 


avec son en-tete 


Ce nest la qu’un premier pas. Avec un peu de travail sur le fichier 
styl e . css, il est possible de changer radicalement l’apparence de la page 
sans ecrire une seule ligne de PHP. 




Colchique 

Car cheque hrin d'herhe est unique... 


Nos Publications | Les Billets | FAQ 

Contactez nous | Deconnectez-vous 
Chercher dans ce site : 


Etat du marche de I'emploi pour les Administrateurs reseaux 


Soumis par Marine le dim.. 0&H/20Q9 - 10:30 

Les administrateurs reseaux connaissentt-ils la crise ? 


Recrutement Systemes et reseaux 


Ajouter un commentaire 

Etat du marche de I'emploi pour les ingenieurs informaticiens 


Soumis par Marine le dim.. 0&H/2009 - 10:23 

La crise touche t-elle les informaticiens ? 


Ajouter un commentaire 

Un nouvel article 

Soumis par Marine le yen , Q&O5/2Q09 - 16:20 

Corps de I'article... 


Recrutement Ingenie rie logiciel 


Ajouter un commentaire 


Figure 11-29 Et maintenant un peu plus travaille 



Pour mieux organiser les balises CSS, vous allez rapidement avoir besoin 
de disposer de plusieurs feuilles de style. II suffit pour cela de modifier le 
fichier mon_theme . i nfo et d’y ajouter un nouveau champ 
styl esheets [al 1 ] []=ma_feui lie. css. Mais attention, en procedant 
ainsi, styl e . css ne sera plus reconnue comme feuille de style par defaut. 
Pour la conserver, il est necessaire d’ajouter un champ supplementaire 
styl esheets [al 1 ] []=style.css. 
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URL jQuery 

► http://jquery.com/ 

► http://plugins.jquery.com/ 


Ajout de nouvelles feuilles de style dans mon_theme.js 

; les feuilles de style specifiques 

stylesheets [all] [] = style. css 

styl esheets [al 1 ] [] = ma_feuille.css 

styl esheets [print] [] = ma_feuille_pour_impression.css 

L’identifiant al 1 signifie « pour tous les medias » et implique que le 
navigateur utilisera la feuille de style en toutes circonstances. II est pos- 
sible de remplacer al 1 par n importe quel media CSS. Par exemple, pour 
une feuille a utiliser uniquement pour l’impression, nous utiliserions 
styl esheets [pri nt] [] = ma_feuille_pour_impression.css. 

Enfin, dans cet exemple, nous disposons les feuilles de style a la racine 
du dossier du theme. II est bien evidement possible de les placer dans un 
sous-repertoire en indiquant cette fois comme valeur au champ un 
chemin relatif au dossier du theme, par exemple styl esheets [all] [] = 
styl es/ma_feui lie. css. 

Pour que Drupal prenne en compte la nouvelle definition de notre 
theme, il nous faut retourner sur radministration des themes. Un simple 
affichage de cette page suffit a forcer la mise a jour des definitions ; une 
fois ceci fait, futilisation des deux feuilles de style est alors activee. C’est 
ainsi que vous pouvez ajouter autant de feuilles de style que vous le 
desirez sans jamais avoir a les inserer vous-meme dans le code XHTML. 
D’ailleurs, a noter, vous ne devez jamais les inserer vous-meme dans une 
page. En effet, Drupal dispose de mecanismes d’optimisation des 
feuilles de style qui ne fonctionneraient pas si vous inseriez une balise 
<1 i nk> dans un des modeles. 

Utiliser les scripts 

Lorsque vient le moment de mettre en place des comportements dyna- 
miques (onglets, effets, menus deroulants, etc.), il est necessaire de pou- 
voir ajouter de nouveaux fichiers JavaScript. Comme pour les styles, 
PHPTemplate cherchera dans le dossier de themes un fichier scri pt . j s 
qui, s’il existe, sera inclus automatiquement dans chacune des pages. 
Pour ajouter d’autres scripts que script, js, le meme principe que pour 
les feuilles de style s’applique, a savoir une modification du fichier 
mon_theme . i nfo. 

Illustrons cette possibility avec un script bien pratique qui arrondit auto- 
matiquement les coins des boites. Le script que nous allons utiliser pour 
cette operation est un greffon pour jQuery. 

JQuery est une bibliotheque tres legere de manipulation du DOM 
( Document Object Model) ecrite en JavaScript, et extensible via des cen- 
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taines de greffons qui lui ajoutent des comportement particuliers : effets, 
animations, boites de dialogue, etc. Par chance, cette merveilleuse 
bibliotheque est aussi la bibliotheque JavaScript de Drupal en standard. 

Le greffon qui nous interesse ici se nomme j Query Corner, et vous 
pouvez le telecharger a partir de l’adresse http://blue-anvil.com/archives/anti- 
aliased-rounded-corners-with-jquery. 

Dans Farchive zip se trouve un fichier j query . curvycorners . packed . js 
qui est la version compressee du greffon. Placez-le dans le dossier du 
theme, et creez dans ce meme dossier un fichier script, js dans lequel 
nous allons ecrire le code en utilisant j Query Corner pour arrondir les 
angles de nos blocs. Nous aurons prealablement etudie ces blocs avec 
Firebug pour decouvrir que ceux se trouvant sur la region Barre de droite 
ont pour chemin CSS #si debar- ri ght .block. 

Contenu du fichier script.js 

Drupal .behavior s.myModuleBehavi or = function (context) { 

$( '#sidebar-right .block . content '). corner({ 


tl : 

{ 

radi us : 

5 

}, 

tr : 

{ 

radi us : 

5 

}, 

bl : 

{ 

radi us : 

5 

}, 

br : 

{ 

radi us : 

5 

}}); 


}; 

L’objet Drupal .behaviors utilise ici est fourni par Drupal pour collecter 
Fensemble des comportements dynamiques, de maniere a ne les activer 
que si JavaScript est lui-meme active par Drupal. Utilisez toujours cette 
methode lorsque vous desirez lancer un script juste apres le chargement 
de la page sur le navigateur client. 

Le corps de la fonction est assez explicite pour qui connait JavaScript : il 
s’agit de rechercher le chemin CSS #si debar- right .block, correspon- 
dant, nous le savons a present, aux styles CSS de nos blocs de droite, 
pour y appliquer le greffon d’arrondissement des coins. 

Pour ceux qui ne connaissent pas encore j Query, son apprentissage vaut 
le detour et FInternet regorge de tutoriels bien construits, y compris en 
fran^ais. 

A ce stade, nos deux fichiers JavaScript ne sont pas encore connus du 
theme. Comme pour les styles, si nous n’avions eu que le fichier 
scri pt . j s, il aurait ete reconnu automatiquement sans avoir a renseigner 
mon_theme . i nfo. Mais, comme nous avons ici deux scripts, nous devons, 
comme pour les feuilles de style, les referencer tous les deux dans 
mon_theme . i nfo. 
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Ajout des scripts dans mon_theme.info 

; declaration des scripts 
scripts[] = script. js 

scripts [] = jquery. curvycorners . packed . js 

Et comme pour les styles, une fois mon_theme . i nfo sauvegarde, nous 
devons repasser par le panneau d’administration des themes pour que 
notre theme soit recharge par Drupal. Ceci fait, et comme par magie, 
vous constaterez que les coins des blocs se sont arrondis. 


Figure 11-30 

Les coins des blocs sont 
automatiquement arrondis. 


Ce qui s'est dit... 


Merci a vous, je vais encore 
il y a 21 heures 57 min 
Article passionnant mais 
il y a 21 heures 59 min 


Second niveau de personnalisation : 
les modeles 

Lorsque les besoins deviennent tres specifiques, ajouter des feuilles de 
style ne nous sera plus d’aucune utilite car c’est l’organisation du contenu 
propre au theme qui s’avere inadaptee. 

Lorsque nous regardons notre « nouveau » theme, nous constatons par 
exemple que les liens secondaires sont places au-dessus des liens primaires. 
Ceci est deroutant si Ton desire y placer les grandes sections de notre site, 
et n est de toute fa^on pas conforme a ce que nous avions decide. 


Figure 11-31 

Mauvaise disposition des rubriques 


N os Publications | Les Billets | FAQ 

Contactez nous | Deconnectez-vous 
Chercher dans ce site : 


Vous l’aurez compris, ce sont les modeles qu il va nous falloir modifier 
car ce sont eux qui mettent en forme chaque element fondamental de la 
page. Dans le cas present, c’est le modele principal, page.tpl .php, qui 
est responsable de la disposition des liens primaires et secondaires. 

Modifier le modele de page 

Avant de proceder aux modifications necessaires au changement de dis- 
position des liens primaires et secondaires, observons quelques instants 
le contenu de notre page . tpl . php : 
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En-tete (simplifie) du modele page.tpl.php 


<html xml ns= M http://www.w3 . org/1999/xhtml " lang="<?php print 
$language->language ?>" xml : lang="<?php print Slanguage- 
language ?>" di r="<?php print $language->dir ?>"> 

<head> 

<?php print Shead ?> 

<titlex?php print $head_title ?></title> 

<?php print Sstyles ?> 

<?php print Sscripts ?> 

</head> 

Nous trouvons ici le squelette complet de notre page codee en XHTML 
et nous observons les insertions en PHP de variables fournies par PHP- 
Template. 

Dans la premiere partie du modele est defini l’en-tete de la page. 
Detaillons un peu les variables dont nous disposons ici. 


Bon A SAVOIR Connaftre le contenu des variables de modele 

Si vous ne savez pas ce que contient une variable particuliere, par exemple Slanguage, 
vous pouvez inserer dans le code (de preference dans le <body> s'il s'agit de 

page . tpl . php) la fonction PHP var_dump (...). 

14 <body> 

15 <?php var_dump ($language) ; ?> 

16 <table border="0" cellpadding=" O" cell; 

17 <tr> 


Figure 11-32 

Cette astuce vous permettra, apres sauvegarde et rafraichissement de la page sur le naviga- 
teur, de lister le contenu complexe d'une variable et ainsi de determiner les informations que 
vous pouvez en retirer. 


object [stdClass) [5] 

public 'language' =■■ string ' f r ' { length=2 ) 
ptiblic 'name' => string 'French' (length=6} 
public 'native' => string 'Franqais' ( length=9 } 
public 'direction' =; string ' G ' (lengtb=l) 
public 'enabled' = string '1' {l ength=l} 
public 'plurals' =: string '2' {length=l} 
public 'formula' = string ' t$n>l ) ' {length=6} 
public 'domain' => string '' {length=&} 
public 'prefix' =-■ string '' {length=8} 
ptiblic 'weight ' = string 'O' (length=V 

public 'javascript' =■■ string ' fddcbd4c68ca6alle685c2a8b9b9f2cG' {length=32} 
public 'dir' => string ' It r ' { length=3 ) 

Figure 11-33 


• Slanguage contient la langue courante utilisee par Drupal. Sa valeur 
est un objet et dispose a ce titre de nombreux champs dont 
$language->language, qui contient la forme abregee de la langue fr. 
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Bonne PRATIQUE Chemin vers une ressource 

Utilisez toujours $base_path dans votre theme 
des que vous avez a indiquer le chemin vers une 
ressource. 

La maniere ideale pour referencer une ressource 
sans se preoccuper du parametrage du serveur est 
de I'utiliser en conjonction avec la fonction 
path_to_theme() qui donne le chemin du theme. 
<?php 

pri nt $base_path . path_to_theme() 

. "/mon_i mage. png" ?> 


• $head_ti tl e contient le titre de la page qui a ete parametre dans Con - 
figuration du site > Informations. 

• Shead est a inclure systematiquement pour permettre a Drupal 
d’ajouter des elements dans l’en-tete selon ses besoins. 

• $styles et $script contiennent respectivement la liste des balises 
d ’inclusions des feuilles de style et des scripts pour la page. A ce titre, 
l’inclusion de ces variables est absolument obligatoire. 

• $base_path contient le chemin de base de Drupal. II s’agit la plupart 
du temps d’un simple slash, mais peut aussi correspondre a une valeur 
plus longue si votre site fonctionne sur une URL du type http://monSite/ 
monDrupal/. Dans ce cas, $base_path aura pour valeur monDrupal/. 

Plus loin dans la page, nous trouvons d’autres variables : 

• Sf ront_page prend une valeur booleenne avec TRUE si le modele est 
utilise pour la page d’accueil du site et FALSE dans le cas contraire. 

• SI ogo contient le code XHTML (essentiellement une balise i mg) per- 
mettant d’afficher le logo du site qui a ete configure dans le theme. 

• $site_name, $site_slogan et Smission contiennent respectivement le 
nom, le slogan et la mission du site qui ont ete parametres dans la 
section Informations. 

• Stitle contient le titre du contenu, a ne pas confondre avec le titre 
du site. Lors de l’affichage d’un noeud, le titre du contenu est le titre 
du noeud. 

• Sbreadcrumb contient le fil d’Ariane de la page. 

• Smessages contient les eventuels messages d’erreur renvoyes par 
Drupal. 

• Shelp contient un eventuel message d’aide contextuel renvoye par 
Drupal. 

• Stabs contient le code XHTML des onglets affiches dans les pages. 

• $primary_l i nk et $secondary_l i nk contiennent respectivement le 
code XHTML pour la liste des liens primaires et secondaires. 

• Sclosure contient les elements XHTML que Drupal doit mettre a la 
toute fin du document XHTML. Cet element est obligatoire, 
comme celui composant la balise body en debut de document et utili- 
sant la variable $body_cl asses. 

• $search_box est le code XHTML de la boite de recherche dans les 
contenus. 

• Scontentest une variable on ne peut plus importante car elle re9oit le 
contenu XHTML d’un noeud (articles, pages, etc.). 

Dans de nombreux cas, vous remarquerez que l’inclusion de ces variables 
est conditionnee par le fait qu’elles ont un contenu (par exemple, <php if 
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(SI ogo) : ?>). Ce mecanisme est utilise pour rendre optionnel l’affichage 
de tel ou tel element en fonction de la configuration du theme, comme 
aborde precedemment. Ainsi, si faffichage du logo est desactive, la 
variable sera vide et le code correspondant non inclus. 

Les dernieres variables que nous trouvons dans ce modele sont celles 
correspondant aux regions que nous avions etudiees dans le chapitre 
« Structurer les pages » : 

• la region En-tete representee par la variable Sheader ; 

• la region Pied de page representee par la variable Sfooter ; 

• la region Barre de droite representee par la variable Sri ght ; 

• la region Barre de gauche representee par la variable $1 eft. 

Fort de cette connaissance, nous avons a present tous les outils necessaires 
pour modifier la presentation des liens primaires et secondaires. Pour ce 
faire, il nous faut avant toute chose reperer les variables Spri mary_l i nks et 
$secondary_l i nks dans le modele, et modifier comme suit en depla^ant le 
bloc de code faisant reference a $secondary_l i nks apres la table. 

Modification de page.tpl.php pour positionner les liens secondaires 

<?php if (i sset($primary_l i nks)) { ?> 

<?php print theme( 

'links' , 

$primary_l inks , 

arrayC'class' => 'links', 'id' => 'navlist')) ?><?php } ?> 

<?php print $search_box ?> 


</td> 

</tr> 

<tr> 


<td col span= ,, 2 ,, xdi vx?php print Sheader ?x/divx/td> 

</tr> 

</table> 

<?php 

if (isset($secondary_l inks)) { ?> 

<?php print theme( 

'links' , 

$secondary_l i nks , 

arrayC'class' => 'links', 'id' => 'subnavlist')) ?> 

<?php } ?> 

II ne reste qua sauvegarder le modele pour observer le resultat sur la 
page d’accueil. 



Figure 11-34 

Les liens secondaires 
correctement places 
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Les liens sont maintenant correctement places, et il suffit de quelques 
modifications supplementaires dans style. css pour rendre tout ceci 
presentable. 
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Figure 11-35 

Nouvelle version 
de I'en-tete 


SS Colchique 

Contactez-nous Deconnectez-vous 

Car chaque brin d'tierbe est unique... 

Chercher dans ce site : 

Les Publications Les Billets FAQ 


Modifier le modele des blocs 

Nous irons un peu plus vite sur ce modele, car il est beaucoup plus 
simple que celui concernant la page. 

Le modele bloc.tpl.php 

<div class="block block-<?php print $block->module; ?>" 
id="block-<?php print $block->module; ?>-<?php print $block- 
>delta; ?>"> 

<H2x?php print $block->subject ; ?></H2> 

<div cl ass="content M x?php print $block->content ; ?x/div> 
</di v> 

S’agissant des variables, ce modele rec^oit juste fobjet $bl ock de la part de 
PHPTemplate. Cet objet contient cependant un certain nombre de 
champs qu’il convient de detailler. 

$block->module et Sblock->delta forment a eux deux un identifiant 
unique pour le bloc. En effet, comme nous favons vu, tous les blocs sont 
fabriques par un module. Il en est de meme pour les blocs que nous 
creons manuellement, qui sont en realite generes par le module Block. 
$block->module contient le nom du module dont est issu le bloc et 
$block->delta contient fidentifiant du bloc genere par ce module. En 
effet, un module peut generer plusieurs blocs et le nom du module seul 
ne suffirait done pas a Y identifier. 

Dans le code de ce modele, Bluemarine utilise ces deux identifiants pour 
associer a chaque <div> representant un bloc : 

• la classe block, commune a tous les blocs ; 

• la classe blockxnom du modul e>, commune a tous les blocs issus dun 
meme module ; 

• fidentifiant blockxnom du modul e>-<del ta du bloc>, qui est speci- 
fique a ce bloc uniquement. 
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Pour connaitre les modules et les deltas dun bloc, que vous visez a tra- 
vers un element de votre feuille de style, le plus simple consiste a l’afifi- 
cher et a utiliser le bouton Inspecter de Firebug. 

Les deux derniers champs relatifs a l’objet Sblock sont $block->subject, 
qui contient le titre du bloc, et $block->content, son contenu. 


Modifier le modele des contenus 

Le modele node . tpl . php est utilise pour transformer un contenu (article, 
page, CCK, etc.) en un fragment de code XHTML, qui sera insere dans 
page. tpl .php a travers la variable $content. Ici aussi, nous sommes loin 
de la complexity de page . tpl . php : 

Le modele node.tpl.php 

<div cl ass="node<?php if (Ssticky) { print " sticky"; } ?> 

<?php if (!$status) { 

print " node-unpublished"; } ?>"> 

<?php if ($picture) { 
print $picture; 

}?> 

<?php if ($page == 0) { ?> 

<h2 cl ass="ti tl e"> 

<a href="<?php print $node_url ?>"><?php print $title?x/a> 
</h2x?php }; ?> 

<span class="submitted"x?php print $submitted?x/span> 

<div cl ass="taxonomy"x?php print $terms?x/di v> 

<div cl ass="content"x?php print $content?x/di v> 

<?php if (Slinks) { ?> 

<div class="l i nks">&raquo; <?php print $1 inks?x/di v> 
<?php }; ?> 

</di v> 

Les variables utilisables dans ce modele sont les suivantes : 

• Ssticky et Sstatus indiquent respectivement si les cases a cocher 
epingler en haut de la page et publier ont ete activees pour le contenu 
que Ton cherche a formater ; 

• Steaser indique si le contexte d’affichage du modele est une vue 
resumee (en page d’accueil, par exemple) ou une vue complete ; 

• $pi cture est un fragment de code XHTML contenant la reference a 
l’avatar de hauteur du contenu. Si cette option n est pas activee dans 
le parametrage du theme, son contenu est vide ; 
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• $page est tres importante car lorsqu’ elle est a TRUE, elle nous previent 
que Ton cherche a afficher le contenu dans son entier ; a FALSE, c’est 
le resume du contenu qui est traite ; 

• Ssubmited contient le code XHTML decrivant l’auteur et la date 
d’ecriture de l’article ; 

• $taxonomy contient un fragment de code XHTML donnant la liste 
des termes de taxonomie qui sont rattaches a ce contenu. Cela 
permet, en cliquant dessus, de faire ressortir les contenus traitant des 
meme themes que l’article ; 

• Scontent contient le code XHTML du corps de la page ; 

• Slink contient le code XHTML de la liste des liens associes au con- 
tenu. Vous y trouverez, par exemple, le lien Ajouter un commentaire ou 
En savoir plus. 

• Snode contient le noeud au grand complet. Elle n est pas utilisee dans 
notre modele mais merite d'etre citee car elle contient toutes les 
informations de base de contenu (ex. $node->title pour le titre). 

Sur ce modele, nous allons combler une lacune du theme Bluemarine. 
En effet, d un point de vue CSS, rien ne nous permet de distinguer si 
notre noeud est affiche dans le contexte d une vue resumee ou d une vue 
complete, alors que cette information nous serait tres utile pour definir 
un affichage different dans chacun des deux cas. 

Modifier le modele des commentaires 

C’est le modele comment. tpl .php qui est charge de formater chaque 
commentaire, de la meme maniere que block. tpl .php formate chaque 
bloc. Lorsque PHPTemplate a effectue le rendu du noeud, puis de 
chacun des commentaires, il fusionne l’ensemble de ces fragments 
XHTML pour le fournir dans la variable Scontent a page . tpl . php. 

Voyons le contenu du modele comment . tpl . php d’un peu plus pres : 

Le modele comment.tpl.php 

<div class="comment<?php print ' Sstatus; ?>"> 

<?php if (Spicture) { 
print Spicture; 

} ?> 

<h3 cl ass="ti tl e"x?php print $title; ?></h3> 

<?php if ($new !="){?> 

<span cl ass="new"><?php print $new; ?></span> 

<?php } ?> 

<div class="submi tted"x?php print Ssubmitted; ?></div> 
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<div cl ass="content M > 

<?php print $content; ?> 

<?php if ($signature) : ?> 

<div class="clear-block M > 

<di v>-</di v> 

<?php print $signature ?> 

</di v> 

<?php endif; ?> 

</di v> 

<div class="links M >&raquo; <?php print Slinks; ?></div> 

</di v> 

Nous avons ici des variables qui ont le meme role que celles utilisees 
pour le modele de contenu : Sstatus, $picture, $title, Ssubmited, 
Scontent. Mais nous y trouvons aussi quelques nouveautes : 

• Ssignature qui contient, si lutilisateur Ta definie et si fadministra- 
teur Ta autorisee, la signature de lutilisateur ; 

• $new qui contient le message « nouveau » lorsquun commentaire a ete 
poste sur ce contenu apres la derniere visite de lutilisateur courant ; 

• Scomment qui contient un objet Commentaire complet, comme $node 
pour le modele node . tpl . php ou Sbl ock pour bl ock . tpl . php. 

Nos seuls changements consisteront ici a corriger un petit probleme 
dans le modele lie a ce double chevron (&raquo;) qui s’affiche au-dessus 
de chaque ligne, puis a supprimer le titre du commentaire qui n’apporte 
pas grand-chose. 

Nous en profiterons aussi pour ameliorer la feuille de style de maniere a 
mettre le portrait de lutilisateur a gauche, a installer une bordure au- 
dessus des liens que Ton alignera a droite, et enfin a supprimer la bor- 
dure bleue autour de chaque commentaire (en jouant sur Tattribut 
border de Tidentifiant CSS comment). 

Ceci fait, nous pouvons rafraichir la page du navigateur pour admirer le 
resultat. 



Par Marine, ts mar. Q&0&2QQ9 - li t 7. 

Merci avous, je vais encore un peu I'ameliorer... 


nouveau 


supprimer editer repondre 


Figure 11-36 

Les commentaires avec les portraits correctement positionnes 


Nous voila arrive au terme du second niveau de personnalisation de 
notre theme qui, en l’etat, est deja tres presentable. Nous pouvons 
cependant aller encore plus loin et modifier encore plus finement cer- 
tains aspects qui nous echappent avec les deux premiers niveaux. 
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Troisieme niveau de personnalisation : 
la fonction themeO 

Pourquoi aller plus loin ? 

Nous avons utilise pour le moment tout ce qui se trouvait dans notre 
dossier mon_theme sans nous poser trop de questions. Cette approche, 
alliee aux feuilles CSS, nous permet de modifier enormement de choses, 
mais nous risquons d'etre rapidement bloque lorsqu il s’agira d’effectuer 
des taches plus complexes, par exemple : 

• faire un modele different pour chaque type de contenu ; 

• fournir a un modele d’autres variables que celles qui nous sont don- 
nees en standard ; 

• modifier des elements qui ne sont pas presents dans le theme, comme 
fapparence des liens ou des images. 

Dans le domaine des themes Drupal, les notions abordees jusqu ici cor- 
respondent au perimetre des connaissances generalement maitrisees par 
la majorite des themeurs. Lorsqu il y a necessite d’aller plus loin, certains 
se lancent alors dans le « bidouillage » de modeles existants, mais ren- 
dent par la meme occasion le systeme fragile et difficile a maintenir. 
Pourtant, a chacune de ces questions existe une reponse et/ou une solu- 
tion precises dans le systeme Drupal de gestion de fapparence. 

Vision generate du systeme de themes de Drupal 

Chaque donnee de Drupal est transformee en code XHTML par ce 
qu on appelle un « hook de theme ». Ne confondez pas ce hook de theme 
avec le theme de site que nous sommes en train de realiser. Un hook de 
theme est une operation de transformation entre une donnee (par 
exemple un objet PHP lien qui contient des champs href, title, etc.) 
et un fragment de code XHTML. 

Les hooks de theme sont definis par les modules actives dans Drupal. 
Chaque module peut definir un nombre infini de hooks. Par exemple, le 
hook de theme qui transforme un objet block en un bloc XHTML est 
defini par le module standard de Drupal, Block. 

Les hooks de theme s’appellent les uns les autres pour creer des codes 
XHTML complexes. Ainsi, a la creation d’une page, c’est le hook de 
theme Page qui est appele ; il va a son tour appeler le hook Node, et plu- 
sieurs fois le hook Blocks pour chacune des regions du theme. A son 
tour, le hook Blocks appellera plusieurs fois le hook Block (sans s), avec 
en parametres les differents blocs de cette region. 
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Pour appeler ce hook, Drupal utilise une seule et unique fonction 
appelee theme () qui prend en premier parametre le nom du hook, et 
pour les suivants les donnees a formater. La construction d une page est 
done une longue serie d’appels imbriques a la fonction theme (). 


theme{' block', $block) 


themeC block 1 , $block) 


the me(' regions 1 , 'left') 


themef 'regions', 'footer') 


themeC node', $node) 



the me {'page 1 , ^content) 


I 


Page 

XHTML 


Figure 11-37 L'enchaTnement des appels de la fonction theme() 


Jusque-la, nous retrouvons une logique que nous connaissons deja. Mais 
en realite, les appels a theme () descendent beaucoup plus loin dans le 
detail quil ny parait de prime abord. theme (’ block’ , ...), par exemple, 
devra afficher des liens, et ainsi faire appel a theme (’link’, ...) . Les com- 
mentates auront besoin damages et ainsi faire appel a theme ( ’ i mage ’ , ...) . 

Vous faurez compris, la moindre donnee de Drupal est tot ou tard for- 
matee en XHTML par un appel a la fonction theme et au hook qui con- 
vient pour cette tache. 

La question qui se pose legitimement est : ou se trouvent les modeles pour 
un lien ou une image ? La reponse depend du choix opere par le module 
lorsqu’il a defini son hook. II dispose en effet de deux methodes : 

• soit il decide que le hook doit etre gere par un autre modele ; 

• soit il prefere confier ce travail de transformation a une simple fonc- 
tion PHP. 

La raison pour ne pas utiliser uniquement des modeles est avant tout une 
question de performances. En effet, une fonction theme ( * 1 i nk’ ) est 
appelee pour chaque lien present sur une page et ce, a chaque fois que la 
page est affichee. Sachant quun modele est en moyenne cinq fois plus 
lent qu une fonction PHP, utiliser des modeles pour de petites donnees a 
formater est tres prejudiciable sur le temps de fabrication de la page. 
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Utiliser les noms de modeles eligibles 

Que le hook soit defini par une fonction ou par un modele, vous avez 
toujours les pleins pouvoirs pour modifier ce comportement par defaut. 

Lorsque le module a defini le hook comme etant gere par un modele, le 
modele par defaut se trouve toujours dans le dossier du module. La pre- 
miere action possible consiste a dupliquer ce fichier dans votre dossier 
theme. Drupal utilisera systematiquement ce qui se trouve dans le dossier 
du theme en priorite par rapport a n’importe quel autre emplacement. 
C’est en realite ce que nous avons fait depuis le debut avec les modeles 
node.tpl .php, block. tpl .php, page.tpl .php et comment. tpl .php, dont 
les versions par defaut se trouvent dans le dossier des modules, respective- 
ment, modules/node, modules/block, module/system et module/comment. 
Vous pouvez y jeter un coup d’oeil pour verifier cela par vous-meme. 

Mais fextension des modeles par defaut ne s’arrete pas la. Pour repondre 
aux besoins que nous avons enonces en introduction de ce chapitre, vous 
avez aussi la possibility de definir des modeles derives a partir d un 
modele principal, qui ne seront utilises que dans certains cas particuliers. 

II est ainsi possible de rendre un modele dependant de certaines condi- 
tions, par exemple un modele de noeud qui ne serait utilise que pour les 
conte nus de type Billet, ou encore un modele de page qui ne s’activerait 
que si FURL est de type rubrique. Le principe est que pour un meme 
hook, il peut y avoir une serie de noms de modeles eligibles, le nom par 
defaut portant systematiquement le nom du hook. 

D’un point de vue pratique, il s’agit simplement de dupliquer le modele 
de base du hook (ex. node.tpl .php) et de le renommer avec un nom 
compatible avec une eligibility et correspondant a votre besoin. Voyons 
maintenant pour chaque grande categoric de hook, les noms de modeles 
derives eligibles. 

Noms de modeles eligibles pour le hook Page 

Pour ce hook, la liste des noms de modeles eligibles est determinee a 
partir du chemin interne de la page. Ainsi, une page avec pour chemin 
interne chemi n/12/page aura la liste de modeles eligibles suivante : 

• page-chemin-page.tpl .php : ce nom de modele est construit a partir 
de tous les elements non numeriques du chemin. En effet, pour 
Drupal, un element numerique est tres souvent un element variable 
faisant reference a un ID en base de donnees. Par exemple, node/1/ 
edi t signifie « la page d’edition du noeud ayant 1 pour ID en base de 
donnees ». Le modele portant le nom page-node-edit. tpl .php per- 
mettrait ainsi de fonctionner pour toutes les pages d’edition quel que 
soit FID du noeud ; 
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• page-chemi n-12-page . tpl .php : c’est-a-dire chacun des elements du 
chemin ; 

• page-chemi n-12 . tpl . php : tous les chemins commen^ant par chemi n/ 
12 (incluant done chemi n/12 tout court) ; 

• page-chemi n . tpl . php : tous les chemins commen^ant par chemi n ; 

• page. tpl .php : le modele de base du hook, qui sera utilise si aucun 
autre n existe. 

A noter que si vous desirez creer un modele specifique pour la page 
d’accueil, vous devez simplement le nommer page-front . tpl . php. 

Enfin, dernier detail, les chemins dont nous parlons ici etant les chemins 
internes, il n est done pas question d’utiliser les alias dans ces noms de 
modele. Si vous donnez un alias societe a node/6, le modele page- 
societe.tpl .php ne fonctionnera pas, il faudra utiliser page-node- 
6 . tpl . php. 

Noms de modeles eligibles pour le hook Node 

Les noms de modeles eligibles pour le hook Node permettent de definir 
un modele specifique a un type de contenu donne. Il est possible de creer 
un modele different pour un contenu de type Page ou Article, tout en 
gardant le modele standard pour tous les autres types. 

Pour construire le nom d un modele de noeud eligible, il faut connaitre 
fidentifiant du type de contenu. La maniere la plus simple est d’aller 
dans fadministration des types de contenu, fidentifiant qui nous inte- 
resse etant indique a la colonne Type. 


Nom Type Description 


Operations 


Article story 
/V 



Un article, similaire dans laforme a 
une page, est ideal pour creer et 
aff i cher du contenu qui informe et 
pousse les visiteurs a reagir. Revues 
de presse, actuality billet de blog 
peuvent etre crees avec un article. Par 
defaut, un article est 
automatiquement publie sur la page 
d'accueil de votre site et permet aux 
visiteurs d'ajouter des commentaires. 


gerer 

modifier les 

champs 


supprimer 


Figure 11-38 

Decouverte du type interne d'un type de contenu 


Une fois le type connu, vous pouvez construire votre nom de modele 
sous la forme node-type . tpl . php oil type est fidentifiant interne du type 
de contenu. Par exemple, pour un modele specifique a un contenu de 
type Article, le nom sera node-story .tpl .php. 

Notez que le meme principe est applicable aux noms de modeles eligi- 
bles pour le hook Comment. Ainsi, le nom de modele comment- 
story, tpl .php sera utilise uniquement pour les commentaires lies a un 
contenu de type Article. 
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Bon A SAVOIR Plus de modeles ? 

II existe encore d'autres hooks proposant une liste 
de noms de modeles eligibles. Vous trouverez une 
liste exhaustive dans la documentation de Drupal, 
a I'adresse : 

► http://drupal. 0 rg/n 0 de/l 9081 5 


Noms de modeles eligibles pour le hook Block 

Nous avons vu quun bloc est defini par le nom du module qui le genere et 
son delta. Ces informations seront utilisees pour definir la liste des 
modeles eligibles : 

• block-modul e-del ta.tpl .php : ici nous avons toutes les informations 
pour un modele specifique a un bloc unique, module et delta sont a 
remplacer par le nom du module et la valeur du delta, par exemple 
bl ock-comment-0 . tpl . php sera le modele eligible pour le bloc de delta 
0 (ce sont les commentaires recents), fourni par le module 
Comment ; 

• block-module. tpl .php, qui sera utilise pour tous les blocs issus dun 
meme module. Par exemple, block-comment .tpl .php sera le nom de 
modele eligible pour tous les blocs du module Comment ; 

• bl ock- region .tpl . php, qui sera utilise pour tous les blocs dune 
region donnee. La valeur de la region sera en general left, right, 
header, footer ou content ; 

• block. tpl .php : le modele par defaut du hook Block si aucun autre 
n a ete trouve. 


Modifier les modeles invisibles 

Jusqu a present, nous avons travaille sur des modeles lies aux hooks Node, 
Block, Comment et Page. Ce n’etait pas trop difficile car n’importe quel 
theme de site fournit une version de ces modeles qu il suffit de modifier. 
Mais qu en est-il des modeles caches au coeur de chaque module ? 

Prenons un exemple. Vous avez peut-etre remarque que depuis factivation 
dans le theme de la prise en charge des portraits dans les commentaires, 
nous avons un probleme : fabsence de portrait pour les utilisateurs ano- 
nymes. Ce nest pas vital, mais pas tres esthetique non plus. 

Drupal propose un reglage pour cela, dans Gestion des utilisateurs > Para - 
metres des utilisateurs , a la section Portraits et dans le champ Portrait par 
defaut. II serait ainsi parfaitement possible de mettre une image dans le 
theme, par exemple, si tes/al l/themes/mes_themes/mon_theme/ 
uti 1 i sateur-i nconnu . png, et de renseigner exactement ce chemin dans 
le champ Portrait par defaut. 

Le probleme de cette approche est son manque de perennite. En effet, 
que se passera-t-il si Ton supprime ce theme pour en mettre un autre ? 
Ou si on deplace le theme dans un autre dossier ? Limage disparaitrait 
en meme temps que le theme, et il y a fort a parier que Ton perdrait du 
temps a comprendre d’oii vient cette anomalie. 
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Une autre option consisterait a modifier le modele comment. tpl .php, ce 
qui ne serait pas bon non plus car nous y ajouterions du code n ayant pas 
grand-chose a faire a cet endroit. En effet, l’image dun utilisateur n est pas 
un element specifique aux commentaires, car nous avons vu qu il etait pos- 
sible de l’activer pour les contenus. Si nous faisons une modification sur ce 
point dans comment. tpl .php, il faudra alors reproduire tout ce code dans 
node. tpl .tpl. Meme si Ton peut s’accorder sur le fait quil est inconce- 
vable qu un utilisateur anonyme ecrive un contenu, ce serait oublier que 
certains utilisateurs authentifies n auront peut-etre pas defini leur portrait. 

La bonne approche consiste done a trouver quel hook est responsable de URL Module Devel 

la fabrication du portrait utilisateur. Cet exercice serait fastidieux si Ton . .. . ; : — r~— ; — r~ 

.. . ,, . 1V ► http://drupal.org/project/devel 

ne disposait pas d un outillage appropne, et en 1 occurrence, de 1 indis- 
pensable module Devel. 

Une fois que vous avez installe ce module, nactivez que les sous- 
modules Devel et Theme Developer. Ceci fait, retournez sur Y article de 
bienvenue. Vous devriez voir apparaitre en bas a gauche de la page une 
etrange petite zone avec une case a cocher Themer info. Cochez la case 
pour faire apparaitre foutil d’aide sous la forme dun panneau. 

Vous avez ici un outil tres proche de Firebug en termes d utilisation. En 
passant la souris sur les differentes zones de la page, un cadre rouge appa- 
rait. Allez sur le portrait de lutilisateur Marine dans le commentaire 
quelle a redige et cliquez dessus. Le panneau vous affiche alors toutes les 
informations a connaitre pour modifier Y apparence du portrait. 


Dm pal Themer Information 

Parents: user-picture. tpl.php comment. tpl.php theme_comment_view 
th e m e_c o m m e nt_th re ad_e xpanded com me nt-w rap p e r.tp I . p h p p ag e .tp I . p h p 

Function called: 

themeJmageO 

Candidate function names: 

mon_theme_image phptemplate_image theme_image 

Duration: Q.8 ms 


Figure 11-39 

Decouverte des fonctions de themes avec le module Devel 


Nous y apprenons que fimage a ete generee par le hook Image a travers la 
fonction theme_image(), mais ce nest pas fimage qui nous interesse ici. 

En regardant en haut du panneau, vous avez la liste de tous les modeles 
qui ont ete appeles en partant de page. tpl. php jusqua comment .tpl.php, 
puis user-picture. tpl .php : la reside finformation interessante. Il 
existe done un modele user-pi cture . tpl . php qui genere le code 
XHTML de notre portrait. 

Letape suivante consiste a comprendre ou se trouve ce modele et pour 
cela, cliquez sur le lien user-pi cture . tpl . php. Le panneau affiche a pre- 
sent des informations plus precises sur ce modele. 
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Figure 11-40 

Decouverte des fonction responsables 
de I'affichage du portrait de I'utilisateur 


Drupal Themer Information 
Parents: comment. tpl.php theme_comment_view 

them e_c omme nt_th re ad_e xpanded com me nt-w rap p e r.tp I . p h p page .tp I . p h p 

Template called: 

user-picture. tpl.php 

File used: 

m o d u I esi' us e r' us e r-p i ctu re .tpl.php 
Candidate template files: 

user-picture. tpl.php 
Preprocess functions: 

template_preprocess + template_preprocess_user_picture 
Duration: 6.4 ms 


Nous voyons id que le modele se trouve dans le dossier modules/user. 
Ce hook est done defini par le module User, ce qui est logique puisque ce 
dernier gere tous les aspects lies a l’utilisateur. 

L’etape suivante consiste a recopier ce modele dans le dossier de notre 
theme et d’en examiner le contenu. 

Le contenu d'origine de user-picture.tpl.php 

<div class="picture M > 

<?php print $picture; ?> 

</di v> 

Comme vous le voyez, il nest pas tres complexe et nous pouvons le 
modifier pour prendre en compte fabsence d’image. 

Notre version de user-picture.tpl.php 

<div class="picture M > 

<?php 

if ($picture) { 

// L' image est disponible, il suffit de l'utiliser 
print $picture; 

} else { 

// L' image n'est pas disponible, nous prenons celle par 

defaut 

print themeC' image' , path_to_theme() . "/util isateur- 
inconnu . png") ; 

} 

?> 

</di v> 

Le code ainsi modifie traitera le cas oil fimage du portrait est inexis- 
tante. Il ne presente aucune difficult^ notable, a fexception de fappel a 
la fonction theme () que nous commen^ons a connaitre. 

• theme () est utilisee ici pour faire appel au hook de theme image avec 
en second parametre le chemin vers fimage a transformer en balise 
XHTML. 

• path_to_theme() est une fonction que vous utiliserez continuelle- 
ment. Elle renvoie tout simplement le chemin vers le theme actif. Il 
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est tres important de toujours utiliser cette fonction pour etre certain 
que, quel que soit l’endroit ou vous mettez votre theme, les ressources 
que vous definissez sont toujours bien accessibles. 



Par Roberta (non verifie ) , le mar, Q&Q&2Q0S - 12:39. 

Article passionnant mais manquant neanmoins un peu de substabce 


Eupprimer editer repondre 



Par Marine . le mar. Q&Q&20Q9 - 11:4 7. 

Merci a vous, je vais encore un peu I'ameliorer... 


Figure 11-41 

Nos anonymes ont 

Eupprimer editer repondre ITiaintenant leur portrait. 


Le resultat de 1’appel de theme est done une balise XHTML <i mg> cor- 
rectement formee et entierement prise en charge par Drupal. Nous pou- 
vons maintenant rafraichir notre article pour verifier que les commentaires 
anonymes sont a present bien dotes d une image par defaut. 


Personnaliser une fonction de theme 

Comme evoque dans la section « Vision generale du systeme des themes 
de Drupal », lorsqu un module defini un hook de theme, il a le choix 
entre Y associer a un nom de modele ou a une fonction PHP. La plupart 
des petits elements (liens, images, libelles, etc.) sont transformes par la 
seconde methode. Comment modifier un comportement non desire 
dans un tel cas de figure ? 

Pour illustrer la solution a ce probleme, nous allons tenter de modifier la 
maniere dont le nom des utilisateurs est presente dans les commentaires. 
En effet, vous avez sans doute remarque fapparition du libelle (non 
verifie) a la droite du pseudo des utilisateurs anonymes. 

Figure 11-42 

Par Roberto (non verifie), _ , . r . , .. 

* — Ce « non verifie » est disgracieux, 

nous allons le faire disparaitre. 


Cette petite phrase indique simplement que le contributeur Roberto n est 
pas un utilisateur authentifie du site. Nous pouvons decider que cette 
« fonctionnalite » n apporte pas grand-chose et nous voulons la supprimer. 

A faide du module Devel, nous allons done pointer ce texte pour trouver 
fidentite du hook et du modele qui sy cachent. 


Drupal Themer Information X 

P are nts : th e rm e_c □ m m e nt_s ubmitted comme nt.tp I . p h p them e_c omme nt_vi e w 
them e_c o m m e nt_th re ad_e xpanded comme nt-w rap p e r.tp I . p h p p ag e .tp I . p h p 

Function called: 

themejJsernameO 

Candidate function names: 

m o n_th e m e_us e rn am e phptemplate_username theme_username 
Duration: 0.71 ms 


Figure 11-43 

Recherche de la fonction de theme responsable 
de Taffichage du nom d'utilisateur 


www.frenchpdf.com 


285 


11 - Modifier Tapparence 




Drupal 6 - Concevoir et deployer ses applications 


£ 


URL Documentation en ligne Drupal 


► http://drupal.org/handbooks 
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Dans ce cas de figure, nous sommes face a une petite nouveaute : il 
semble qu’aucun modele ne prenne directement en charge le rendu 
visuel de ce nom d’utilisateur, le dernier modele evoque en haut du pan- 
neau etant notre classique comment . tpl . php. 

En revanche, nous apprenons que l’integralite du libelle Nom d'utilisateur a 
ete genere avec la fonction theme_username(). Nous sommes done dans le 
cas de figure dun hook (username) associe non pas a un modele, mais a une 
fonction PHP. Pas de panique : comme pour les modeles, Drupal permet de 
remplacer n importe quelle fonction de theme par votre propre version. 

Si nous nous interessons a la section Candidate function names (litterale- 
ment « Noms de fonction eligibles »), nous decouvrons une liste de noms 
de fonction classes par priorite (de la plus forte a la plus faible). Comme 
pour les modeles, nous pourrons fabriquer nous-meme lime de ces fonc- 
tions pour prendre a notre charge F apparence du nom d’utilisateur. 

Lorsque la fonction theme( ‘ username ) sera lancee, elle cherchera 
F une de ces fonctions en choisissant en priorite la premiere de la liste, ici 
mon_theme_username . De maniere plus generique, lorsque 
theme ( ‘ nom_du_hook’ , ...) est appele, les fonctions suivantes sont 
recherchees : 

• <nom_du_theme>_<nom_du_hook> : comme notre theme a pour nom 
mon_theme et que le hook s’appelle username, il s’agit pour nous de la 
fonction mon_theme_username, comme Findique le panneau du 
module Devel ; 

• phptemplate_<nom_du_hook> : ce qui nous donne pour le hook 
username le nom de fonction phptempl ate_username. Cette fonction 
est a utiliser avec prudence, car rien n empeche deux themes actifs de 
Femployer. Beaucoup de themes utilisent ce format de nom de fonc- 
tion, avant tout pour des raisons historiques ; preferez done la version 
precedente ; 

• theme_<nom_du_hook> : e’est l’implementation par defaut du rendu 
XHTML pour le nom d utilisateur, utilise par Drupal si aucune des 
fonctions precedentes n existe. 

Pour creer notre propre fonction mon_theme_username, nous allons nous 
inspirer de la version d’origine theme_username. Pour ce faire, vous 
pouvez la rechercher dans les sources de Drupal, ou plus simplement cli- 
quer sur le nom de cette fonction dans le panneau du module Devel. 
Vous etes alors dirige automatiquement sur la documentation en ligne 
(en anglais) de l’API Drupal, un site qui est la reference de tout ce qui 
touche au developpement de ce CMS. 
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theme_username 

| Drupal 4.7 ] | Drupal 5 | | Drupal 6 | | Drupal 7 | 

includes/theme. inc, line 1601 
Versions 

4*7-7 theme_username($object) 

Format a username. 

Parameters 

$object The user object to format, usually returned from user_load[). 

Return value 

A string containing an HTML link to the user's page if the passed object suggests that this is a site user. Otherwise, only the 
username is returned. 

Related topics 

Default theme implementations Functions and templates that present output to the user, and can be implemented 
by themes. 

Code 


<7php 

function theme_username( $obj ect ) ■{ 

if £ $obj ect ->uid $obj ect ->name) -[ 

// Shorten the name when it is too long or it will break many tables 
if £ drupal_strlen( $obj ect ->name) > 20) { 

$name = drupal_substr ( $obj ect ->name, 0, 15) 

1 

else { 

$name = $obj ect ->name; 

1 

Sur cette page se trouvent des explications sur le role de la fonction, sur 
ses parametres et valeurs retournes, ainsi que sur le code source de la 
fonction. Ne faites pas toujours confiance a ce code qui est la a titre 
d’exemple. Lmformation interessante ici est le nom de fichier ainsi que 
la ligne oil se trouve le code de la fonction dans les sources de Drupal. 
Ouvrez done avec un editeur le fichier i ncl udes/theme . i nc, a la 
ligne 1 601 pour trouver la fonction theme_username. (Notez quelle ne 
sera peut-etre pas exactement a cette ligne, preuve quil ne faut pas 
accorder une confiance aveugle en la documentation.) A la fin de la 
fonction, vous trouverez le code qui nous pose probleme. 

La fonction theme_username, la partie ajoutant (not verified) 

} else { 

$output = check_pl ai n($object->name) ; 

} 

$output .= ’ (’. tC’not verified') 

} else { 

$output = vari abl e_get( ' anonymous ' , t( 'Anonymous ')) ; 
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Figure 11-44 

L'aide en ligne sur la fonction 
theme_username 
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Bon A SAVOll Les traductions dans le code 

Notez au passage dans le code que nous venons de 
commenter I'utilisation de la fonction t() dans 
t ( * not ve r i f i ed ’ ) . Cette fonction est au 
systeme de traduction de Drupal ce que theme () 
est au systeme de themes. Le principe general est 
que tous les textes d'un module ou d'un theme con- 
tenus dans du code PHP doivent etre d'une part 
ecrits en anglais, d'autre part toujours passes dans 
cette fonction. C'est cette fonction qui traduit les 
termes anglais dans n'importe quelle langue prise 
en charge par Drupal. C'est aussi elle qui rend pos- 
sible I'extraction de toutes les chaTnes de caracteres 
a traduire pour un theme ou un module donne, afin 
de les fournir a un traducteur. 


} 

return $output; 

} 

Nous allons a present creer notre propre fonction mon_theme_username. 
Pour cela, il nous faut commencer par creer un fichier tres important 
appele tempi ate . php dans le dossier du theme. 

Ce fichier est le seul qui doit contenir du code PHP complexe dans votre 
theme : n en mettez done jamais ailleurs, et surtout pas dans les modeles. 

Une fois le fichier cree, ajoutez la balise PHP en tete du fichier (<?php) 
et recopiez a sa suite la fonction theme_username, avant de renommer 
cette fonction mon_si te_username. Nous pouvons des lors tranquille- 
ment desactiver cette ligne de code qui ajoutait (non verifie) en la mettant 
en commentaire. 

Modification de la fonction mon_theme_username() 

} else { 

$output = check_pl ai n($object->name) ; 

} 

// Soutput .= ' ('. t C ' not verified') 

} else { 

Soutput = vari abl e_get( ' anonymous ' , t( 'Anonymous ')) ; 

} 

return Soutput; 

} 

Si nous testions notre theme des maintenant, cela ne fonctionnerait pas 
encore. En effet, Drupal ne cherche pas - pour d’evidentes raisons de 
performances - a relire le code de tous les modules et de tous les themes 
pour decouvrir de nouveaux hooks de theme ou fonctions de theme. II 
effectue cette operation appelee « construction du registre de theme » 
uniquement lors de ^activation dun theme. 

Pour proceder aux tests, deux solutions se presentent a nous. La premiere 
consiste a aller dans le panneau d’administration des themes, et le seul fait 
d’afficher cette page provoque la reconstruction du registre des themes. 

L autre methode - a manier avec precaution - consiste a forcer la recons- 
truction en ajoutant en tete de votre fichier template. php fappel a la 
fonction drupal_rebui ld_theme_regi stry(). Ainsi, lorsque vous rafrai- 
chirez votre page (via la touche FR), le registre sera automatiquement 
reconstruit. 

Vous pouvez maintenant rafraichir la page pour juger du resultat et de la 
disparition du libelle (non verifie). 
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Article passionnant mais man quant neanmoins un peu de substabce 



Pa: Roberto , le mar, Q&Q&2QQ9 - 11:39. 


supprimer editer repondre 



-gV Pa: Marine „ le mar. 0&Q&2Q09 - 11:4 7. 

Merci avous, je vais encore un peu I'ameliorer... 


Figure 11-45 

Nos commentaires maintenant « parfaits » 


supprimer editer repondre 


Voila, nos commentaires sont maintenant parfaits. Attention, pensez a 
toujours mettre en commentaire Tappel a la fonction 
drupal_rebuild_theme_registry() une fois la base reconstruite, sans 
quoi vous nuirez fortement aux performances de votre Drupal, car le 
registre sera systematiquement reconstruit pour chaque page affichee. 

Enrichir les variables d’un modele 

Pour le moment, nous avons uniquement compte sur les variables qui 
nous etaient fournies en standard dans un modele. II ne s’agit la en 
aucun cas d une limitation, car Drupal nous offre bien entendu la possi- 
bility d’en ajouter autant que necessaire. 

Bonne PRATIQUE Utilisez intensivement Tenrichissement des modeles 

L'enrichissement en variables d'un modele est un aspect tres important, 
car c'est ce qui assurera une bonne independance entre la presentation 
(les modeles) et les donnees. Ne sachant pas comment enrichir les varia- 
bles d f un modele, beaucoup de themeurs ajoutent du code metier direc- 
tement dans les modeles PHP, les rendant ainsi tres difficiles a lire, pour 
ne pas dire illisibles, et surtout tres dependants des donnees. 

L/exemple critique de cette mauvaise pratique est ^utilisation de 
requetes SQL lourdes dans les modeles, dupliquees sur des dizaines de 
modeles differents : un veritable enter a traquer pour effectuer des ope- 
rations de maintenance ou devolution. Lorsque nous avons besoin 
d'afficher une nouvelle donnee non prevue dans le modele d f origine, la 
seule chose qui doit apparaTtre dans le modele est une variable 
$ma_nouvelle_donnee, et rien d'autre. Le modele doit toujours rester 
une chose simple. Quelques tests, des variables, et c'est tout. 

Le cas pratique que nous allons aborder pour illustrer cette possibility 
consistera a ajouter a notre theme une nouvelle region. Pour finstant, 
heritant de Bluemarine, mon_theme utilise par defaut les cinq regions 
standards de PHPTemplate. Imaginons que nous voulions mettre en 
place une sixieme region qui se placerait juste au-dessus du contenu, et 
juste en dessous de l’en-tete. 
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La premiere chose a faire est cTindiquer a Drupal la presence de cette 
region. Pour cela, nous allons ajouter de nouvelles informations au 
fichier mon_theme . i nfo. Le principe de mon_theme . i nfo est que tout ce 
qui n’y est pas specific - ici les regions - beneficie de valeurs par defaut 
(les cinq regions standards). En revanche, si nous ajoutons une nouvelle 
information, celle-ci remplacera toutes les valeurs par defaut qui ne 
seront alors plus utilisees ; il nous faut done dans mon_theme .info definir 
six regions, sans quoi nous perdrions lusage des cinq regions fournies au 
depart en standard. 

Ajout des six regions a mon_theme.info 

regions [1 eft] = Left sidebar 
regions [right] = Right sidebar 
regions [content] = Content 
regions [header] = Header 
regions [footer] = Footer 
regions [content_top] = Content Top 

Nous utilisons pour cela la syntaxe regions [identi fi ant_regi on] = Nom 
de la region. Vous constaterez que les identifiants de region correspondent 
aux noms des variables de region que nous avons etudiees avec le modele 
page.tpl .php : $left, $right, $content, $header et $footer. II s’agit la 
d une convention permettant aux personnes qui utilisent le theme de s’y 
retrouver facilement. En ajoutant la region conte nt_top, nous indiquons 
ainsi que nous allons mettre a disposition une variable $content_top. 

Notez seulement que ces identifiants doivent suivre les memes regies 
qu’un identifiant PHP (pas d’espace, d’accent, de tiret, etc.). 

Une fois le fichier mon_theme . i nfo sauvegarde, fetape d’enrichissement 
a proprement parler peut commences Comme pour la personnalisation 
d une fonction de theme, fenrichissement des variables d un modele 
passe par la creation d une fonction dans tempi ate . php. La difference ici 
reside dans le fait que toutes les fonctions eligibles seront executees les 
unes apres les autres. C’est pour cela que nous parlons d’enrichissement 
et non de redefinition. Vous mettrez ainsi dans le corps de ces fonctions 
uniquement les variables que vous souhaitez ajouter. 

Comme pour les fonctions de theme, deux noms de fonction sont utilisa- 
bles, phptempl ate_preprocess_<nom du hook> et <nom du 
theme>_preprocess_<nom du hook>. Dans notre exemple avec le hook 
Page, cela nous donnera en guise de noms phptempl ate_preprocess_page 
et mon_theme_preprocess_page. Comme pour les fonctions de theme, 
nous donnerons preference a la seconde possibility. 

Cette fonction va prendre en parametre un tableau associatif (cle => 
valeur). Ce parametre utilise logiquement un passage par reference 

www.frenchpdf.com 


(&$vari abl es) pour en permettre la modification par le corps de la fonc- 
tion. Lorsque ce tableau devra etre donne au modele, chaque cle 
deviendra une variable prenant la valeur correspondante, ce qui nous 
donnera le code suivant a mettre a la suite dans tempi ate . php . 

La fonction d’enrichissement des variables du theme Page 

function mon_theme_preprocess_page(& $variables) { 

SvariablesC'content-top'] = themeC' blocks ' , 'content-top') ; 

} 

Nous retrouvons ici la fonction theme - utilisee cette fois-ci sur le hook 
Blocks - qui prend en parametre l’identifiant de la region. Ce hook 
cherchera automatiquement tous les blocs presents sur cette region et 
renverra leur rendu XHTML. Ce rendu est stocke dans le tableau 
$variables a la cle content_top, qui lors du passage du modele, donnera 
la variable $content_top. 

La derniere etape est l’utilisation de la variable $content_top dans le 
modele page.tpl .php, action qui se fait tres simplement en inserant le 
code PHP correspondant : 

Ajout de la nouvelle region dans le modele 

<?php print $help ?> 

<?php print $content_top; ?> 

<?php print $content; ?> 

<?php print $feed_icons; ?> 

II ne nous reste qu a rafraichir le registre des themes par Y une des deux 
techniques donnees a la section precedente, avant d’aller observer le 
resultat dans le panneau d’administration des blocs. 

Entete 

Aucun bloc dans cefie region 

Pied de page 

-f Pied de page du site | Pied de page C | configurer supprimer Figure 11-46 

content Top Apparition de notre nouvelle region 

Air*' i in riaric ratio ronfnn 

Choisissez un bloc dans le stock des blocs desactives - par exemple, Pro- 
pulse par Drupal faites-le glisser dans la region En-tete , puis enregis- 
trez. Comme vous le voyez, le logo Drupal apparait bien au-dessus du 
contenu, la region est done operationnelle. 

egalementcreer un liloc personalise 


Content Top 

Bloc Region 


Figure 11-47 

La nouvelle region en action 
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Nul besoin de laisser ce bloc ici, mais ce type de region peut s’averer par 
exemple tres utile pour inserer des blocs de publicite. 

Enrichir les variables de tous les modeles 

Nous savons a present enrichir les variables dun modele lie a un hook 
particular, mais il existe des situations dans lesquelles vous aurez besoin 
de transmettre une variable a tous les modeles, tous hooks confondus. 
Un grand classique illustrant ce besoin est de mettre a disposition de 
tous les modeles une variable $is_admin qui contiendra TRUE si l’utilisa- 
teur est l’administrateur, et une variable $logged_i n qui contiendra TRUE 
si lutilisateur est authentifie. 

Le principe est ici tres proche de ce que nous venons de voir pour l’enrichis- 
sement en variables des modeles par hook. Ce sont peu ou prou les memes 
noms de fonctions qui sont eligibles, et elles procedent exactement de la 
meme maniere avec les memes parametres. Ce sont 
phptempl ate_preprocess et <nom du theme>_preprocess, ce qui dans 
notre exemple nous donne phptempl ate_preprocess et 
mon_theme_p reprocess : la meme chose sans le nom d un hook, en somme. 

Pour ajouter nos deux variables, nous allons done inserer dans 
tempi ate. php la fonction mon_theme_preprocess . Nous utilisons ici la 
meme technique que celle employee pour conditionner l’affichage d un 
bloc au fait que lutilisateur soit un administrateur. 

Enrichissement de tous les modeles avec $is_admin et $logged_in 

function phptempl ate_preprocess(& $variables) { 
global $user; 

$variables[' is_admin'] = $user->uid == 1; 
$variables['logged_in '] = ($user->uid > 0) ? TRUE : FALSE; 

} 

Une fois tempi ate . php enregistre et le registre des themes rafraichi, nous 
pouvons utiliser les variables $is_admin et $logged_in dans nimporte 
quel modele. 


Le resultat 

Nous voila arrive au bout de notre premiere exploration des themes de 
Drupal qui se conclut par deux petites captures d’ecran (voir double- 
page suivante), Y une du theme Bluemarine avant que nous commen- 
cions a y toucher, et l’autre de notre theme final. 
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Alors bien evidement, pour preceder toute critique, un graphiste the- 
meur professionnel, arme de toutes ses competences en graphisme et en 
ergonomie, aurait produit un theme beaucoup plus beau. Mais l’objectif 
ici n est pas de viser l’excellence esthetique mais de demontrer a quel 
point le moteur de theme de Drupal est souple et somme toute, avec un 
petit effort d’apprentissage, facile a mettre en oeuvre. 


En resume 


• Un modele est un fichier PHP auquel le moteur de theme, PHP- 
Template, fournit des variables. 

• Lorsque vous devez changer quelque chose dans un theme, com- 
mencez toujours par les feuilles de style. Si ce nest pas suffisant, 
changez les modeles, et si cela ne repond toujours pas a votre besoin, 
ajouter de nouvelles variables et/ou fonctions de theme. 

• Chaque element dune page (et la page elle-meme) dispose d un nom 
de modele, et d’une serie de noms de modeles eligibles prenant en 
charge les cas specifiques (ex. node-story .tpl .php). 

• Ne mettez jamais de code dans un modele. Les seules instructions 
qui doivent s y trouver sont pri nt et i f . Si vous avez besoin de plus, 
cela signifie que vous devez enrichir le modele avec de nouvelles 
variables. 

• Le moindre aspect visuel de Drupal est modifiable par le theme, soit 
par un modele, soit par une fonction de theme. Le module Devel est 
l’outil ideal pour decouvrir ce que vous devez surcharger. 

• Un theme doit fonctionner dans nimporte quel dossier. Ne mettez 
jamais un chemin en dur, utilisez toujours $base . path_to_theme() 
pour recuperer le chemin vers une ressource. 

• Si vous avez besoin d’aide, n hesitez pas a poser vos questions sur le 
forum http://drupalfr.org, dans la section Developpement. 
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Colchique 

Car ciiaqtie brin dtierbe est unique... 


Chercher dans ce site : 


_ 

| Les Billets | FAQ 

Contactez-nous 

1 

|| Recherche | 


Accueil 

Bienvenue 

So u m is par Marine le 8 juillet 2009 - 11:11am 

Bienvenue sur le site Colchique Conseil, 

le cabinet de conseil en ressources humaines qui a I'ethique au fond du coeur. 


La societe Colchique 

T Qi 

□ Nos vale urs 

O 

o Historique 
o Les chiffres clef 


Vous trouverez sur notre site une presentation complete, des ses intervenants et de ses valeurs. Vous 
pourrez aussi decouvrir nos publications ainsi que nos billets d'humeur. Bonne visite L 'equips 

http:uVv w w.colchiq ue-consei.fi'. 1 ' c? 


Fichier attache 

Taille 

La copie d'ecran 

105.4 Ko 

Le manuel utilisateur 

274.03 Ko 

Moyenne : 





Votre notation : Aucun Moyenne : 3 (1 vote) 

» Ajo uter un commentaire 


Article passionnant mais 

Par Roberto (non verified le S juillet 2009 - 12:03pm. 

Article passionnant mais manquant neanmoins un peu de substance. 

repondre 


Ce qui s'est dit... 

* Merci a vous, je vais encore 

il y a 22 heures 9 min 

* Article passionnant mais 

il y a 22 heures 11 min 


Rejoignez-nous... 

Horn d'utilisateur : * 


Mot de passe : * 


| Se connecter | 

* Creer un nouveau compte 

* Demander un nouveau mot 

de passe 


Merci a vous, je vais encore 

Par Marine, le S juillet 2009 - 12:04pm. 

Merci a vous, je vais encore un peu I'ameliorer... 

repondre 



© Colchique Conseil - Tout droits reserves - Ce site est pro pulse par Drupal. 


Figure 11-48 Le theme Bluemarine d'origine 
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Colchique 


Car chaque brin tffoeibe est unique... 


Contactez-nous 


Chercher dans ce site : 


Les Publications Les Billets FAQ 



Figure 11-49 Notre theme dans sa version finale 


295 


www.frenchpdf.com 


11 - Modifier I’apparence 










chapitre 



Abonnements Flux Element Vue Outils Recherche Aide 
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drupal.org 


^ planet e drupal.fr [1) 
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© NewsForge 

F Framasoft 
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MozillaZine-Fr 

fa Freelancelnformatique.com 
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l> M Drupal 
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0 


Date 


^ Tit re 


m mar. 13:01 WIKI d 'organisation de la reunion de prise de contact.. 

dim. 13:57 Mettre a jour Drupal 

ven. 19:11 DrupalGon Paris: Pour que tout le monde soit la! 


ven. 17:33 


I'm coming to DrupalGon Paris video avalanche 


^ DrupalGon Paris: Pour que tout le monde soit la! 


Classe sous drupalcon park, Isabell 5, Marketing 
Createur Drupal Groupe France 

marqueur marque-page link cosmos 


La fondation DrupalGon Scholarship offre 60 bourses pour que des etudiants, 
des developpeurs et des contributeurs qui ont besoin d'un soutien financier 
puissent participer a la DrupalGon Paris 2009. Grace a nos sponsors et a 
tous les animateurs de la iournee Formation c'est devenu possible ! 

II y a deux types de bourses - CloseTheGap et Local - qui couvrent une 
partie ou la totality des couts de I'entree, du voyage et de I'hebergement. 

Vous pouvez trouver plus d'lnformation sur le site de la DrupalGon Paris fen 
anglais). 

j— | Nous acceptons les candidatures via le site DrupalGon Paris 2009 . Soumettez g 
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Ajouter des fonctionnalites 


Le coeur de metier de Drupal est la gestion des contenus 
et il s’en acquitte fort bien. Cela etant dit, un site web moderne 
se doit de proposer un certain nombre de fonctionnalites 
transversales, car l’internaute d’aujourd’hui s’attend tres 
naturellement a les y trouver. Ainsi, recuperer un contenu 
en version imprimable ou en format PDF, etre notifie 
par courriel lorsqu’un nouveau commentaire a ete poste dans 
une de ses discussions, disposer de son Gravatar, ou encore 
s’authentifier par son identifiant OpenID, entre autres, 
forment un ensemble de services sur lesquels il n est plus 
possible de faire l’impasse. Drupal fournit en standard bon 
nombre d’entre eux, et nous verrons qu il suffit d’y ajouter 
une poignee de modules judicieusement choisis pour obtenir 
un site repondant a toutes les attentes, ou presque. 


SOMMAIRE 

► Ajouter la syndication 
a votre site 

► Prendre en charge I'OpenlD 
et les Gravatars 

► Permettre I'impression 
et la generation de PDF 

► Mettre en place la notation 
des contenus 

► Creer sa propre liste 
de diffusion 
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Qu’est-ce qu’un flux RSS ? 

De maniere tres simplifiee, RSS est un format de document normalise 
fonde sur un autre format normalise, le XML, qui permet l’echange 
d ’informations entre deux programmes informatiques. 

On appelle « flux RSS » un document au format XML/RSS telecharge a 
partir d’un site web par un autre site web ou par une application. Ce 
document contient simplement une liste d’items comme une liste d’arti- 
cles, ou encore une liste de commentaires pour un article. Un site web 
peut publier plusieurs flux RSS, et dans notre cas avec Drupal, nous 
pouvons publier par exemple le flux des nouveaux articles, le flux de tous 
les nouveaux articles rattaches a un terme de taxonomie donne, ou 
encore le flux de tous les nouveaux commentaires lies a un article. 

Chaque flux peut contenir les contenus complets (titre, introduction et 
corps) ou une version allegee du contenu (le titre seul ou le titre et 
l’introduction). Enfin, chaque flux contient un nombre specifie des der- 
niers items a prendre en compte (ex. les 5 derniers articles publies, les 5 
derniers commentaires postes, etc.) 

L’ application ou le site qui lit ce flux RSS ira a intervalle regulier - par 
exemple toutes les 30 minutes - le relire pour detecter les eventuels nou- 
veaux articles ou commentaires publies. On dit alors que l’application ou 
le site est « abonne au flux RSS » ou « syndique au flux RSS ». 

Les lecteurs de flux 

Les applications des flux RSS sont nombreuses. D’un point de vue utili- 
sateur, ils ont permis l’apparition de lecteurs de flux RSS - des applica- 
tions bureautiques tres proches en termes d’interface d’un logiciel de 
messagerie - permettant de suivre les nouveautes sur des centaines de 
sites en meme temps. Si vous ajoutez le flux RSS de votre site a un tel 
outil, ce dernier ira voir ce qui s’y trouve de neuf. Ces logiciels permet- 
tent, si le flux RSS contient les articles en version complete, de se passer 
d’une visite sur le site reel. 

Dans cette categorie de logiciels, pour GNU/Linux, citons Liferea pour 
le bureau Gnome ou Akregator pour le bureau KDE, ou encore Feed- 
Reader sous Windows. II existe aussi des versions web de tels logiciels 
comme le tres celeb re Netvibes (www.netvibes.com). 
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*g\ DLFP - D epee lies [12) 

{§) Framablog (1) 

MozillaZine-Fr 

& Freelancelnformatique.com 
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dim. 13:57 Mettre a jour Drupal 

ven. 19:1 1 DrupalGon Paris; Pour que tout le monde soit lal 

ven, 17:33 I'm coming to DrupalGon Paris video avalanche 


^ DrupalGon Paris: Pour que tout le monde soit la! 


Classe sous drupalcon paris, Isabell S, Marketing 
Createur Drupal Groupe France 

marqueur marque-page link cosmos 

La fondation DrupalGon Scholarship offre SO bourses pour que des etudiants, 
des developpeurs et des contributeurs qui ont besoin d'un soutien financier 
puissent participer a la DrupalGon Paris 2009. Grace a nos sponsors et a 
tous les animateurs de la iournee Formation e'est devenu possible ! 

II y a deux types de bourses - CloseTheGap et Local - qui couvrent une 
partie ou la'totalite des couts de I'entree, du voyage et de I'hebergement. 

Vous pouvez trouver plus d'information sur le site de la DrupalGon Paris [en 
anglais). 

Nous acceptons les candidatures via le site DrupalGon Paris 2009 . Soumettez v 
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Figure 12-1 Le lecteur de flux RSS Liferea pour Gnome 


Une autre utilisation des flux RSS consiste a faire communiquer les sites 
web entre eux. Generalement, il s’agit dun site web qui va interroger les 
flux RSS de plusieurs sites et agreger le resultat en une page web, ou 
meme un autre flux RSS. 

Les sites interroges traitant en general des memes sujets d’interet, ces 
agregateurs jouent ainsi le role de portails thematiques permettant a ses 
utilisateurs d’avoir en un coup d’oeil les nouveautes sur un sujet donne 
provenant de plusieurs sites differents. 

Dans le monde du libre, de tels sites sont connus sous le nom de 
« planet ». Citons par exemple http://planet-libre.org qui regroupe les sites 
parlant des logiciels libres en general, mais aussi http://planet.drupalfr.org qui 
est un planet regroupant les sites fran9ais parlant de Drupal. 



Figure 12-2 

Circulation de I'information RSS entre les differents sites 
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Vous l’aurez compris, les flux RSS sont en quelque sorte des tuyaux, et il 
est bien evidemment possible de s’abonner au flux RSS dun planet, uti- 
lisable sur un lecteur de flux RSS, comme vous le constatez sur la copie 
d’ecran ci-dessous. 


Planet Libre 

Planet regroupant les sites Francophones sur Linux et les Logiciels Libres . 


ff 


ACCUEIL ARTICLES FOPULAIRES ARCHIVES MOBILE SCREENSHOTS FORUM 5TATI5TIQUES PROMOTION 


Acces rapide aux 10 derniers articles 


03/06/2009 : Les systemes Sexploitation open source sortis au mois de mai 2009 
03/06/2009 : Publicity Microsoft. Peut mieux faire ? 

03/06/2009 : Zabbix, un excellent logiciel de supervision reseau 
03/06/2009 : Un livre de recettes pour Vim 
03/06/2009 : En vrac quelques liens 
03/06/2009 : Jamendo en Python/GTK ! 

03/06/2009 : Partagez ! 

03/06/2009 : Ad Bard, le Google Adsense (killer) du logiciel libre ? 

03/06/2009 : Et Drupal je decouvris 

03/06/2009 : Mercurial : editor I'historique d'un depot (les changesets) avec les MQ 


Page suivante > 


Les systemes Sexploitation open source sortis au mois de mai 

2009 4 votes 

Par Scoffoni, le 03/06/2009 a 23:34. ® O 

Voici done venu le moment de faire ce petit point mensuel sur les systemes d'exploitation open source sorties durant le 
mois ecoule. Comme toujours, cet article est base sur les informations donnees par le site Distrowatch.com. 

Un petit coup d J o e i I a leur classement des distributions. Pour rappel ce classement est issu des taux de consultation 
des fichiers de chaque distribution. Ce n'est pas un classement dans habsolu. II reflete tout au plus Nnteret des 
internautes pour une distribution. Ubuntu est toujours en tete suivi de Fedora et Mint qui sont au coude a coude. Pas 
devolution majeur ce mois-ci. On notera hentree d'ArchLinux dans le Top 10. 


Recherche 


ok 


S'abonner 

£3 Fil de tsus les articles 
S3 Fil articles populates 
0 Fil des Screenshots 
0 Fil du Forum Libre 
Q Fil Identi.ca ou Twitter 

En direct du Forur 

Statistiques 

Inscription 

Recherche un logiciel de 
gestion libre 
Inscription 
Inscription 


A propos 


Le contenu des 
syndiques sur ce Pla 


Figure 12-3 http://planet-libre.org, un planet dedie au monde du libre 


Flux des contenus 

Pour activer les flux RSS dans Drupal, il y a peu de choses a faire car 
cette possibility est disponible en standard. 

Pour acceder aux flux de vos articles, 1TJRL est toujours la meme : 
http://www.colchique.fr/rss.xml. C’est cette adresse qui devra etre fournie aux 
applications RSS et aux sites d’agregation pour qu’ils puissent s’y abonner. 

Si vous avez un outil vous permettant de telecharger ce document (par 
exemple wget http://www.colchique.fr/rss.xml sous Unix), vous 
obtenez alors le contenu suivant : 
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<?xml version="1.0" encodi ng="utf-8 M ?> 

<rss version="2 .0" xml : base="http : //dev. drupal 6 . karma-1 ab . net" 
xml ns :dc="http://purl . org/dc/el ements/1. l/"> 

<channel> 

<ti tl e>Col chi que</ti tl e> 

<1 i nk>http : //dev .drupal 6 . karma-1 ab . net</l i nk> 

<descri pti onx/descri pti on> 

<1 anguage>f r</l anguage> 

<i tem> 

<title>Mon premier article</title> 

<1 i nk>http : //dev . drupal 6 . karma-1 ab . net/node/4</l i nk> 
<description> 

&1 t;p&gt;Ceci est 1 ’ introduction de mon 
article&l t ;/p&gt ; 

</description> 

<comments>http : //dev .drupal 6 . karma-1 ab . net/node/ 
4#comments</comments> 

<category domai n="http : //dev .drupal 6 . karma- 1 ab . net/ 
taxonomy/term/3">Recrutement</category> 

<pubDate>Wed , 03 Jun 2009 00:13:30 +0000</pubDate> 

<dc : creator>Mari ne</dc : creator> 

<guid i sPermaLi nk="fal se">4 at http : //dev. drupal 6 . karma- 
1 ab . net</gui d> 

</i tem> 

</channel> 

</rss> 

Ce document a ete ici intentionnellement reduit a un seul article. Nous 
retrouvons dans la balise channel, le titre du site et son adresse. Et pour 
l’item, le titre de l’article, le lien qui y mene, sa description, la taxo- 
nomie, un lien vers commentaires, l’auteur et la date de creation. 

Si nous jetons un coup d’oeil au code source de notre page de garde en 
faisant un clic droit puis en selectionnant Afficher le code source , nous 
trouverons dans la page XHTML le code suivant : 

Balise d’insertion d’un flux RSS dans une page XHTML 

<link rel="al ternate" type="appl i cati on/rss+xml " 

ti tl e="Col chique RSS" href="http : //www. col chi que-consei 1 . fr/ 

rss.xml" /> 

Ce code indique au navigateur qu’il existe un flux RSS nomme 
« Colchique RSS » disponible a FURL http://www.colchique-conseil.fr/rss.xml. 
Lorsqu un navigateur lit cette information dans la page qu il affiche, il 
detecte automatiquement le flux et le signale au visiteur en pla£ant le 
symbole des RSS (voir ci-contre) a fextreme droite de la barre d’adresse. 
Le visiteur peut alors cliquer sur ce symbole pour s’abonner au flux RSS 
de notre site. S’il utilise par exemple Mozilla Firefox, le flux sera automa- 



Figure 12-4 

Symbole des flux RSS 
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tiquement transforme en « marque-page dynamique ». II est possible de 
parametrer le navigateur pour qu une telle action ajoute automatiquement 
ce flux a une application client RSS qui aura ete prealablement installee. 

Par defaut, Drupal a limite le contenu de l’i tem au titre et a l’introduc- 
tion. Pour changer ce comportement, vous devez aller dans Gestion de 
contenu > Publication RSS. Ici, vous avez la possibility de choisir le 
nombre d’articles a placer dans le flux, ainsi que le contenu de chaque 
element de ce flux, ce qui pourra etre le titre seul, le titre et le resume, ou 
enfin le texte complet. Nous allons selectionner Texte Entier. 


Mon premier article 

Classe sous Recrutement 

Createur Marine 

marqueur marque-page commentaires link cosmos 

Ceci est ^Introduction de mon article 


Figure 12-5 

Notre article vu par un lecteur RSS 


Et ceci est son developpement. 


Modules magiques Des flux au format Atom 

Atom est un autre format de flux, lui aussi cons- 
tant sur XML. Sa difference majeure avec RSS est 
que ce format a ete normalise par I'lETF dans la 
RFC 4287. Quant a choisir entre Atom et RSS ? La 
reponse est surement, les deux. 

Pour prendre en charge les flux Atom avec Drupal, 
vous avez seulement besoin d'installer le module 
Atom. 

► http://drupal.org/project/atom 


Une fois la configuration enregistree, retournons sur l’agregateur et fai- 
sons une mise a jour manuelle. Cette fois, les articles sont bien complets. 

Flux par taxonomie 

Toujours en standard, Drupal vous permet de disposer dun flux de nou- 
veaux articles pour chacun des termes d une taxonomie. Imaginons que 
nous voulions creer TURL du flux des articles traitant de 
« recrutement », un terme de notre taxonomie qui a par exemple pour 
identifiant 3. LURL du flux associe a ce terme serait alors : 
http://www.colchique-conseil.fr/term/3/feed. 

Vous pouvez construire ainsi n importe quelle URL pour tous les termes 
de taxonomie, comme nous l’avons etudie, et ajouter a la fin /feed pour 
transformer cette URL en flux RSS. 

Notez enfin que Drupal permet au navigateur d’identifier le flux de tous 
les articles associes a la page de garde, de la meme maniere qu il affiche 
un resultat de recherche lie a un terme de taxonomie donne. Ainsi, si 
vous cliquez sur le lien Recrutement sur un de nos articles, en plus de la 
liste des articles traitant du recrutement, vous verrez apparaitre le sym- 
bole RSS a droite de la barre d’adresse : il permettra de s’abonner au flux 
RSS des articles traitant de recrutement. 
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Flux des commentaires 

Drupal gere l’extension RSS qui permet de disposer des commentaires 
dans les flux d’articles, mais il peut cependant etre interessant de dis- 
poser d un flux specifique aux commentaires. Cette tache est realisable 
par le module Comment RSS, qui va venir etendre le systeme de gestion 
des flux aux commentaires suivants : 

• commentaires publies sur tout le site par FURL http://www.colchique- 
conseil.fr/crss ; 

• commentaires lies a un noeud particulier par FURL http://ww.colchique- 
conseil.fr/crss/node/XXX (XXX etant le numero du noeud) ; 

• commentaires de tous les noeuds rattaches a un terme de taxonomie URL Module Comment RSS 

particulier par FURL http://www.colchique-conseil.fr/crss/term/XXX (XXX etant . .. . ; : — r~ — 

f \ \ ► http://drupal.org/project/commentrss 

le numero du terme). 

Une fois le module installe et active, vous disposez d un nouvel onglet 
Comment RSS settings dans le reglage de la Publication RSS que nous 
venons d utiliser, vous permettant de definir precisement les flux mis a 
votre disposition. 

Par consequent, lorsque vous cliquez dans la page d’accueil de Firefox 
sur le symbole du flux RSS situe a droite de la barre d’adresse, une liste 
des abonnements possibles apparait : 


| http://www.colchique-conseil.fr/node 


a ii v 

1 Construction du site Gestion du contenu Configuration du site Gestion des utilisateurs Rapports £i r 

S'abonner a « Colchique - All comments «... 


M M • l ' . . . 1 

co/cn/qt/e 

car chaque brin d'herbe est unique... 

Chercher dans ce 


Figure 12-6 Selection d'un flux RSS avec Mozilla Firefox 

Creer des flux personnalises 

Drupal en standard ne permet pas de creer des flux pour autre chose 
quune taxonomie ou pour Fensemble des conte nus. Mais en utilisant 
une fonctionnalite du module Views, il est possible de generer un flux 
RSS pour a peu pres n’importe quel besoin. 

Lun des interets du module Views est qu il permet pour un meme para- 
metrage de generer plusieurs affichages. Nous avons deja exploite cette 
possibilite pour nos vues 1 i ste_des_publ i cati ons et 1 i ste_des_bi 1 1 ets 
avec un affichage de type Page qui nous a permis de disposer d un 
chemin d’acces et d une page permettant de naviguer dans la liste. 

Pour un meme parametrage par defaut, le module Views peut aussi nous 
permettre de creer un affichage de type Flux, qui n est autre chose quun 
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flux RSS. Nous avons done la la possibility de transformer nimporte 
quelle liste de n importe quel type de contenu en flux. 

Si nous retournons dans le parametrage de la vue 
1 i ste_des_publ i cati ons, il suffit de selectionner dans la liste deroulante 
en haut a gauche, l’entree Flux, puis de cliquer sur Nouvel affichage. 


Figure 12-7 

Ajout d'un affichage Flux 
pour une vue existante 


Parametres par . 

defaut 

Par an 

Para 

Etiqi 

Page 


Page : 1 

Para 

Agenda interact if 

Nom 

Bloc 

Titre 

Fichier attache 

Style 

Flux 

Style 

Page 

Utilis 


Une fois l’affichage cree, comme pour l’affichage Page, nous pouvons definir 
son chemin d’acces dans la section Parametres du flux. Cliquez sur Aucun 
pour saisir le chemin articles/rss.xml, puis cliquez sur Mise a Jour. 


Figure 12-8 

Parametrage du chemin du flux 


Flux: Le chemin on I'URLde menu pour cette vue 

http w w .co Ic h iq Lie -co n se i I .f r/ 

[publicationB/rss.xml 

Cette vue seraaffichee en visitant ce chemin survotre site. Ilest lecommande que le 
chemin so it du type "pBthfly%/fssd" ou "path. , ’9^i ,1 3^i , 'l^.xm^ , et de pbcer un caractere % 
dans le chemin pourchaque aigument que vous avez defini dans b vue. 

Mise a jour J |Annuler 


Nous devons ensuite definir a quelle page ce flux doit etre rattache, e’est- 
a-dire dans quelle page l’icone RSS correspondante devra s’afficher dans 
la barre d’adresse du navigateur. Pour cela, nous commenc^ons par cliquer 
sur le lien Attach er a : Aucun, avant de cocher Page puis de cliquer sur 
Mise a jour. 


Figure 12-9 

Parametrage de Tattachement 
automatique du flux a la page 


□ Parametres par defaut 
IZJ Page 


Dans le bloc Parametres de base, pour la valeur du champ Style de ligne , 
vous avez normalement Plugin de style manquant. Pour corriger cela, cli- 
quez sur cette valeur et selectionnez Node, puis Mise a jour. Apparait alors 
le choix du type d’affichage. Vous pouvez laisser Utiliser le parametrage RSS 
par defaut, qui a l’avantage de reprendre la configuration que nous avons 
deja choisie pour fensemble des flux Drupal. Cliquez sur Mise a Jour. 
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Nous allons a present modifier le titre de notre flux en cliquant sur le champ 
litre et en saisissant « Colchique - Flux des derniers articles publies ». 


Para metres de base 

Nom: Flux 

Til re Colchique -Flux 
des derniers an ides 
publies 

Style: FluxRSS # 

Style de ligne: Hoeud ft 

Elements a afficher: 10 
Distinct: Non 
Acces: lllimite 

Exposed form in block: Non 
Entele: Aucun 
Pied de page: Aucun 
Texte de page vr de Aucun 
Thomg: Informations 


Figure 12-10 

Parametrage du titre du flux 


Le parametrage est maintenant termine, vous pouvez enregistrer. Cliquez 
maintenant sur la section Les publications de la barre des liens secon- 
daires. Vous devez alors voir apparaitre dans la barre d’adresse du naviga- 
teur le symbole indiquant qu’un flux RSS est disponible. Vous pouvez 
vous y abonner pour juger du resultat. 


^ ■ Libre f1©8) 

A Planet Libre [19) 

%'■ Colchique - Les derniers articles public. 


Date a Titre 

0* Aujourd'hui 18:18 Mon premier article 

Aujound'hui 1 8 : 1 S Mon premier article 


Figure 12-11 

Notre nouveau flux vu a travers 
le lecteur RSS Liferea 


Comme vous le voyez, le module Views peut constituer un outil tres 
puissant pour generer des flux RSS totalement personnalises, construits 
a partir de requetes complexes et auxquels on pourra adjoindre toutes 
sortes de limitations. 


Ajouter la notification sur les nouveaux 
commentaires 

Une fonction basique et pourtant absente par defaut dans Drupal con- URL Module Comment Notify 

siste a proposer au visiteur - anonyme ou authentifie - lors d’envoi d un r 

r \ ........ . . , . ► http://drupal.org/project/comment_notify 

commentaire, la possibility de suivre la conversation qui sensuit. Ce 

manque est comble tres facilement grace au module Comment Notify. 

Plus encore, ce module permet aussi de notifier hauteur d un contenu 

qu un nouveau commentaire a ete poste. 

Une fois ce module active, dirigez-vous vers Administrer > Configuration 
du site > Comment Notify. Le module n a pas encore ete traduit, tout est 
done ici en anglais. 
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Tout d’abord, selectionnez les types de contenu pour lesquels la notification 
doit etre activee : Article et Billet. II est d’ailleurs un peu dommage que 
hauteur n ait pas prevu de faire verifier par son module les reglages des com- 
mentaires pour les types de contenu. De ce fait, il nous propose ici Page et 
Reference , pour lesquels les commentaires sont de toute fa^on desactives : 


Figure 12-12 

Choix des types de contenu 
qui disposeront de la notification 


Content types to enable for comment notification : 

0 Article 
0 Billet 
D Page 
U Reference 

Comments on content types enabled here will have the option of comment notification. 


Comme vous le savez, un commentaire peut etre soit une reponse a 
farticle ou au billet, soit un reponse a un commentaire precedent. II est 
done possible de definir quel type de notification vous desirez activer, ainsi 
que les valeurs par defaut pour lutilisateur anonyme ou authentifie : 


Figure 12-13 

Choix du mode de souscription 


Available subscription modes : 

0 All comments 
0 Replies to my comment 

Choose which notification subscription styles are available for users 

Default state for tbe notification selection box for anonymous users : 

All comments 0 ) 

Default state for tbe notification selection box for registered users. : 

All comments 0 | 

This flag presets the flag for the follow-up notification on the form that anon users will see when posting a comment 


Ensuite viennent les deux modeles de courriels eux aussi en anglais, cor- 
respondant aux messages envoyes, pour le premier a un commentateur 
qui veut etre notifie, pour h autre a hauteur de farticle pour le prevenir 
qu un nouveau commentaire a ete poste. Dans les deux cas, a Y instar des 
modeles de courriels que nous avons etudies dans le chapitre 6 concer- 
nant la creation des nouveaux utilisateurs, plusieurs variables peuvent 
etre inserees pour completer le texte. La liste de ces variables est dispo- 
nible en dessous de chaque modele. 

Lorsque le parametrage vous convient, il ne reste plus qu a Enregistrer la 
configuration et aller dans le parametrage des droits d’acces pour activer les 
permissions concernant ce nouveau module. Cela consiste a accorder le 
droit subscribe to comments (souscrire au suivi des commentaires) aux roles 
Utilisateur anonyme et Utilisateur identifie, et le droit administer comment 
notify (administrer les notifications de commentaires) au seul role Contri- 
butes. 
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Ceci etant fait, changez d’identite pour devenir Marine et cliquez sur 1 

Mon compte. A la fin de la page, vous devriez decouvrir une nouvelle sec- 
tion Comment follow-up notification settings, permettant a Marine de rece- 
voir des notifications a son adresse courriel des qu’un nouveau 
commentaire est poste sur fun de ses articles. Cochez juste la case 
Receive node follow-up notification e-mails et enregistrez le profil. 


▼ Comment follow-up notification settings 

0 Receive node follow-up notification e-mails 

Check this box to receive an e-mail notification for follow-ups on your nodes (pages, forum topics, etc). You 
can not disable notifications for individual threads. 

Receive comment follow-up notification e-mails : 

All comments C | 

Check this box to receive e-mail notification for follow-up comments to comments you posted. You can 
later disable this on a post-by-post basis... so if you leave this to YES, you can still disable follow-up 
notifications for comments you don't want follow-up mails anymore - i.e. for very popular posts. 


Figure 12-14 

Reglage des souscriptions 
dans le profil de Tutilisateur 


Pour tester si tout fonctionne correctement, deconnectons-nous et pos- 
tons un commentaire en tant que visiteur anonyme sur lun des articles 
de Marine. 

Dans le formulaire de creation du commentaire, vous remarquerez que 
de nouvelles options sont maintenant disponibles : 


0 Notify me when new comments are posted 

® All comments O Replies to my comment 


Figure 12-15 

Selection des notifications pour un article 


Modules magiques 

Etre notifie des nouveaux commentaires 

Le module Comment Notify est tres important pour 
permettre la communication avec les utilisateurs 
anonymes (c'est-a-dire les internautes n'ayant pas 
de compte sur notre site). Meme s'il fonctionne 
egalement tres bien pour les utilisateurs authenti- 
fies, il existe plusieurs modules Drupal capables de 
gerer les notifications de fagon beaucoup plus evo- 
luee comme Subscriptions et Notifications. Le 
second est dairement plus riche que le premier, et 
permet d'aller beaucoup plus loin que le simple 
envoi de courriels, avec notamment la gestion des 
SMS, de Twitter, etc. Mais en contrepartie, il est 
egalement plus lourd a mettre en oeuvre. 

► http://drupal.org/project/subscriptions 

► http://drupal.org/project/notifications 


URL Module Simplenews 

► http://drupal.org/project/simplenews 


Apres la validation du commentaire, Marine reg:oit un courriel la noti- 
fiant de cette contribution. Si elle repond, Tutilisateur anonyme reg:oit a 
son tour un courriel a Tadresse qu’il a fourni dans le formulaire. 

Dans ce courriel, Tutilisateur dispose dun lien de desabonnement lui 
permettant de ne plus etre notifie a Tavenir. Le cas echeant, il reste tou- 
jours possible de desabonner un utilisateur en saisissant son adresse 
courriel dans Tonglet Unsubscribe du parametrage du module. 


Ajouter une lettre d’informations 

La gestion des bulletins d’informations peut etre effectuee grace a divers 
modules dont Simplenews, qui reste le plus connu. 

Une fois active, le module Simplenews a cree pour vous un bulletin par 
defaut que vous pouvez parametrer en allant dans Administrer > Gestion 
du contenu > Bulletins. 
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Figure 12-16 

Activation du module Simplenews 


▼ Mail 

Active Nom Version Description 

Send newsletters to subscribed email addresses. 
Simplenews 6.x- 1.0 -re 6 Depend de : Taxonomy (enabled) 

Requis par : Simplenews action (enabled) 

Simnlene ws P rovi d e onsforS i m P |en e 1 ws . 

0 ^ 6.X- 1.0 -re 6 Depend de : Simplenews (enabled). Trigger (enabled). Taxonomy 

aCBOn (enabled) 


Bulletins 


Ajo Liter un bulletin 


Figure 12-17 

Modification du bulletin 


Nom dn bulletin 

Colchique newsletter 


A bonnes Operations 

0 id iter le bulletin 


Pour modifier le bulletin par defaut, cliquez sur editer le bulletin. Vous 
pouvez ici changer le nom du bulletin ainsi que sa description. Notez 
que ces deux informations ne sont pas envoyees aux abonnes et sont la a 
des fins de classement. 

Les informations importantes concernent l’expediteur, dont vous pouvez 
regler le nom et fadresse courriel. 


Figure 12-18 

Definition des coordonnees de I'expediteur 


Informations concern ant I leaped iteur 


Expedite ur : 


[Colchique 


Adresse courriel de Texpediteur : 

| b u I leti n@co Ic h iq ue -conseil.fr] 


Ceci fait, vous pouvez enregistrer votre bulletin et eventuellement en 
creer de nouveaux dans fonglet Ajouter un bulletin. 

La seconde etape consiste a ajouter le bloc permettant a vos utilisateurs de 
recevoir le bulletin d ’informations. Pour cela, allez dans l’administration 
des blocs pour trouver celui correspondant au bulletin que nous venons de 
configurer. Deplacez-le dans la region Barre de droite et enregistrez. 


Figure 12-19 

Ajout du bloc d'inscription aux bulletins 


4* 

Gommentaines necents 

Barre de droite 

Cl 

configurer 

4* 

Bulletin : Colchique 






Barre de droite 

0 | 

configurer 


newsletter* 




4* 

Navigation 

Barre de droite 

JAI 

configurer 


Vous devriez alors voir apparaitre le bloc d’inscription au bulletin. 
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Colchique newsletter 

Tenez-vous au courantde nos 
dernienes nouvellesl 


Utilisateur : 

administrateur 

I M ' ab ° nner | Figure 12-20 

Publications Le bloc d’enregistrement 

pour les utilisateurs identifies 


II s’agit la du bloc specifique aux utilisateurs authentifies ; pour rendre 
disponible la lettre d’informations aux anonymes, vous devez aller cocher 
la permission S'abonner a des bulletins pour le role utilisateur anonyme. 
Ceci etant fait, deconnectez vous pour verifier que cela fonctionne. 


Colchique newsletter 

Tenez-vous au courant de nos 
dernieres nouvellesl 


Courriel : 


® M'abonner 
' Medesabonner 

[ Enregistner | F j gure 12 _21 

Publications p^cedentos Le bloc d’enregistrement 

pour les utilisateurs anonymes 

Le bloc etant maintenant en place, nous pouvons y saisir une adresse de 
test pour verifier quil est operationnel. Ceci fait, Drupal nous previent 
que la demande a ete prise en compte et qu un courriel a ete envoye a 
l’adresse indiquee pour finaliser l'inscription. 


Vous recevrez sous peu un courriel de confirmation contenant les instructions necessaires 
pour completer votre demande d'abonnement. 


Figure 12-22 

Message de confirmation d'un abonnement 


II suffit alors de cliquer sur le lien de confirmation re£u par courriel pour 
valider completement l’inscription. 


Etes-vous sur de vouloir abonner : lesl@amumeral.fr a : Colchique newsletter ? 
Vous pouveztoujours vous desabonner plus tard. 

M'abonner jAnnuler 


Figure 12-23 

Page de confirmation de I’abonnement 
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Figure 12-24 

La liste des abonnements en cours, les petits 
ruisseaux feront les grandes rivieres... 


Bonne pratique Des adresses qui 
ne vous appartiennent pas 

Faites tres attention aux actions que vous effec- 
tuerez avec des adresses de courriel collectees. Ne 
perdez jamais de vue que ces adresses ne vous 
appartiennent pas, qu'il est illegal de les revendre 
et illegal de les utiliser pour d'autres fins que celles 
choisies par les personnes qui vous les ont commu- 
niquees. II n'est par exemple pas acceptable 
d'abonner automatiquement a des bulletins les 
utilisateurs qui ont cree un compte. Notez egale- 
ment que si la frequence d'envoi de bulletins est 
superieure a celle que vous annoncez, vous risquez 
d'etre catalogue comme fournisseur de pourriels 
(ou spammeur), ce qui peut avoir des conse- 
quences legales. 
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Nous avons maintenant un nouvel utilisateur abonne a notre bulletin. Nous 
pouvons confirmer cela en retournant, en tant qu’ administrateur, dans la 
section Administrer > Gestion du contenu > Bulletins, puis Abonnements. 


Filtres d'abonnement 

Abonne a : 

Adi esse de courriel : 


Options de mise ajour 
| Activer 0 | ! Mise ajour | 

□ Co Uriel Nom d' utilisateur Statut Operations 

□ test@arnumeral.fr bl modifier 

L’ergonomie de cette page est devenue pour nous classique, avec sa pos- 
sibility d’appliquer des filtres et des actions a une selection donnee. 

Si vous desirez abonner des utilisateurs a partir d une liste d’adresses de 
courriel, vous devez passer par fonglet Abonnement en masse. II vous 
suffit alors de saisir les adresses de courriel - une ligne par adresse dans 
la zone de saisie de cocher le bulletin sur lequel fabonnement s’appli- 
quera sans oublier la langue a utiliser par defaut, puis d’appuyer sur le 
bouton M 'abonner. 

De la meme maniere, vous pouvez, avec fonglet Desabonnement en 
masse, desabonner une serie d’adresses d’un ou de plusieurs bulletins. 

Enfin, fonglet export vous permet d’abonner automatiquement vos utili- 
sateurs a un ou plusieurs bulletins d’informations. 

Pour terminer, vous pouvez affiner le parametrage du module Simplenews 
en allant dans Configuration du site, puis Simplenews. Les parametres par 
defaut sont normalement parfaitement operationnels, et en cliquant sur 
Bulletin, nous allons juste modifier l’adresse courriel d’essai qui nous per- 
mettra de valider f envoi des bulletins, sans pour autant les envoyer reelle- 
ment. Dans la section Adresses courriel pour les essais, saisissez une adresse 
de test que vous etes sur de pouvoir consulter, puis enregistrez. 

II est maintenant grand temps de creer puis d’envoyer notre premier bul- 
letin. Pour le module Simplenews, un bulletin est un type de contenu 
comme les autres. La creation d’un nouveau bulletin s’effectue done sim- 
plement par un clic sur Creer un contenu de type Newsletter Issue. Mais 
avant tout, nous allons cependant prendre une precaution, en allant editer 
le type de contenu Newsletter Issue pour desactiver dans les options de 
publication la case a cocher Placer en page d'accueil. En effet, les bulletins 
ne sont pas faits pour etre visibles en premiere page de notre site. 


Toljs les bulletins 


[ F litre | 
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Le formulaire que vous voyez apparaitre ne devrait pas vous depayser, 
exception faite du champ Newsletter qui permet de selectionner le type 
de bulletin correspondant a celui que vous desirez creer. 


Title : * 

|Bienvenue 

Newsletter : 

| Colchique newsletter 0 j 


► Parai neti es du menu 


Corps : 


Greer un resume k partir du curseur 


Bienvenue sur la NewsLetter de Colchique 
L'equipe. | 


Figure 12-25 Redaction de notre premier bulletin 


Modules magiques Les courriers en HTML 

Comme pour les autres types de contenu, vous 
pouvez selectionner le format d'entree qui vous 
convient le mieux. Notez cependant que si vous 
desirez utiliser une notation XHTML, vous devrez 
aussi installer le module MimeMail, qui n'etait pas 
encore disponible en version stable pour Drupal 6 
au moment de la redaction de cet ouvrage. Si vous 
tenez malgre tout a I'utiliser, vous devez apres 
I'avoir active aller dans Administrer > Configu- 
ration du site > Simplenews puis Bulletin 
pour changer le format du bulletin de texte brut a 
HTML 

► http://drupal.org/project/mimemail 


La section Envoy er le bulletin vous permet maintenant de controler l’etat 
de votre bulletin : 

• Ne pas envoyer maintenant indique que ce bulletin sera conserve dans 
les « brouillons » apres enregistrement ; 

• Envoyer le bulletin a I'adresse d'essai nous permet de tester notre bul- 
letin sans pour autant l’envoyer reellement, en utilisant I’adresse 
d’essai que nous avons saisie plus haut ; 

• Envoyer le bulletin provoque l’envoi du bulletin. Notez que cet envoi 
n’est pas immediat, comme nous le verrons un peu plus loin. 

Pour l’instant, laissez la valeur a Ne pas envoyer maintenant et enregistrez 
votre bulletin. II sera alors stocke dans les brouillons. Vous pouvez avoir 
acces a la liste des bulletins en brouillon en allant dans Gestion du 
contenu > Bulletins puis Version de Brouillon. 


Aff i cher les publications de 
tous les bulletins C j | Filtre | 


Figure 12-26 

L'etat d'expedition des bulletins 


Titre Bulletin Date de creation Publie Envoye Modifier 

Bienvenue Colchique newsletter 06/05/2009 - 01:08 El J3 modifier 


Vous pouvez alors modifier votre bulletin jusqu’a ce qu’il vous convienne. 

Pour tester ensuite l’envoi, effectuez une derniere modification en selec- 
tionnant l’option Envoyer le bulletin a I'adresse d'essai , puis appuyez sur le 
bouton Sauvegarder et envoyer un test. Un message Drupal vous notifie 
alors de la bonne expedition du bulletin, que vous devriez recevoir a 
I’adresse d’essai. Comme le bon usage l’impose, vous constaterez que le 
bulletin re^u contient a la fin un lien permettant de se desabonner. 
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Retournez maintenant dans la liste des brouillons et modifiez a nouveau 
le contenu pour choisir cette fois-ci l’option Em/oyer le bulletin, puis enre- 
gistrez. Le bulletin a des lors disparu de la liste des brouillons, mais il 
nest pas pour autant envoye reellement. Si vous allez dans Gestion du 
contenu > Bulletins , puis Publications envoyees , vous retrouvez votre bul- 
letin avec une petite horloge en guise d’icone dans la colonne Envoye. 


Figure 12-27 

Le bulletin est en attente d'expedition. 


Aff i cher les publications de 
tous les bulletins 0 Filtre 

Title Bulletin Dale de creation Publie Envoye Modifier 

Bienvenue Colchique newsletter 06/05/2009 - 01:08 S 0 1 modifier 


Cette horloge signifie que le courriel est en attente d’envoi avant le pro- 
chain passage de cron, le planificateur de taches. 

Comme nous l’avons vu lors de Installation de notre plate-forme de 
developpement (chapitre 5 « Administrer Drupal et ses modules »), nous 
n avons pas configure cron pour qu il se lance automatiquement. Nous 
allons done l’executer a la main pour completer notre test. Pour cela, 
dans un nouvel onglet, entrez 1TJRL http://www.colchique-conseil.fr/cron.php. 
Le sablier tournera un certain temps avant de s’arreter sur une page 
blanche. Les taches planifiees, dont Tenvoi du bulletin, ont done ete exe- 
cutees. Pour le verifier, retournez sur l’onglet precedent et pressez F5 
(actualiser). 


Figure 12-28 

Le bulletin est maintenant expedie. 


Titl e Bdletin Date de creation Puhlie Envoye Modifier 

Bienvenue Colchique newsletter 06/04/2009 - 23:08 E2 ^ modifier 


Lhorloge a bel et bien disparu, et la coche nous indique que le bulletin 
est parti. Nous pouvons le verifier en jetant un coup d’oeil a notre messa- 
gerie et en constatant que le bulletin est bien arrive a l’adresse de notre 
unique abonne. 

Le contenu du bulletin re^u 

BIENVENUE 


Bienvenue sur la NewsLetter de Colchique 
L ’ equi pe . 


-- Me desabonner de ce bulletin: 

http://www.col chi que-consei 1 . f r/newsl etter/confi rm/remove/ 
7ebba8ad571t4 
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Prendre en charge I’OpenlD 

L’explosion du Web 2.0 et le developpement de l’usage de l’lnternet 
nous ont dote dune multitude d’identites numeriques : a chaque inscrip- 
tion sur un nouveau site, un nouveau couple nom dutilisateur/mot de 
passe s’ajoute a notre (deja longue) liste d’identifiants a retenir. 

Parce que cela peut devenir tres vite difficile de s’y retrouver, OpenID 
fournit une reponse a cette schizophrenic numerique en vous permettant, 
avec les sites qui le prennent en charge, de ne plus jamais saisir d’identi- 
fiant et de mot de passe. Le principe est tres simple : il vous suffit de creer 
un compte sur un serveur OpenID pour obtenir un identifiant OpenID 
que vous utiliserez sur tous les sites qui prennent en charge OpenID en 
lieu et place du traditionnel couple identifiant/mot de passe. 

Choisir son serveur OpenID est done une etape importante, car e’est lui 
qui hebergera les informations sensibles (e’est tout de meme de votre vie 
privee quil s’agit). Le site http://www.openidfrance.com est un choix accep- 
table car gere par une equipe de benevoles surement moins interesses par 
le profit qu’ils pourraient tirer de cette somme d’informations person- 
nelles que d’autres organismes professionnels. Voyons d’abord comment 
creer un compte OpenID sur ce serveur, pour ensuite examiner la fac^on 
dont Drupal gere ce type d’identifiants. 

Pour commencer, allez a l’adresse http://www.openidfrance.fr et cliquez sur le 
lien Creei votre OpenID. 

Vous devez alors saisir un nom d’utilisateur, un mot de passe et une 
adresse courriel valide pour recevoir la confirmation de l’inscription, puis 
cliquez sur Enregistrer. 


Reference Identite numerique 

ffl 0. Iteanu, L' identite numerique en 

question - 10 scenarios pour la maitrise 
juridique de son identite sur Internet, 
Eyrolles, 2008 


Inscription OpenID France 

Choisissez un identifiant qui va devenirvotre unique adresse OpenID pourvous connecter atous les sites 


Nom d'utilisateur 
Mot de passe 

Confirmez votre mot de passe 
Email 


Gaston 


gaston@colchique-conseil.fr 



Recopiez exactement les lettres dans I'ordre dans ce dessin 
(e'est une securite pourvous enregistrer la premiere fois). 

lY TSVB l ~ 1 


Enregistrer 


Figure 12-29 

La page de creation d'OpenID France 
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Figure 12-30 

Vous avez maintenant 
votre propre identifiant OpenID. 


Une fois que vous avez re^u le courriel de confirmation, cliquez sur le 
lien qui vous est fourni, et c’est termine ! 

I OpenID 

1 France 

Accueil | Decouwir OpenID | Creez votre OpenID | Les sites OpenID | 


Le compte est active. 


Sur le site OpenID, connectez-vous a present avec votre identifiant et 
votre mot de passe dans la boite de connexion en haut a droite pour 
entrer dans votre espace personnel. Vous voyez alors apparaitre votre 
nouvel identifiant OpenID. 


Figure 12-31 

Cette page vous donne votre adresse OpenID, 
ainsi que le moyen d'utiliser I'adresse de votre 
serveur comme identifiant OpenID 
(voir a parte). 


Votre adresse OpenID est 

| h LLp://w w w .open id l"mncc.fr/g os Id n 


Vous avez un site internet ou un blog, vous souhaitez I'utiliser comme identifiant GPEHID ? 
C'esttres simple, il vous suffit de recopier le code ci-dessous entre les balises =head> <\head> : 


<1 j n k rcl— "openid .server' " h ref— " h w w .open idfrancc.fr/iiidc3i .php" f> 

<1 j n k rcf'opcriid .delegate" h ncf= " h LLp://w w w ,o pen idf rn ncc.fr/g as Id nf ' f> 


Modules magiques Votre propre URL comme identifiant OpenID 

Par defaut, votre OpenID est celui fourni dans la premiere zone de votre 
ecran de connexion. Si le site que vous etes en train de creer est votre site 
personnel et que vous avez achete un nom de domaine, il existe un module 
tres pratique, OpenID URL, qui permet d'utiliser I'adresse de votre site 
comme identifiant. Une fois active, vous pouvez le parametrer en allant 
dans Configuration du site, puis OpenID URL. La, vous devez remplir les deux 
premiers champs avec les valeurs donnees dans la seconde zone de I'ecran : 

• Open ID Server : http://www.openidfrance.fr/index.php 

• OpenID Delegate : http://www.openidfrance.fr/gaston 

Une fois cette configuration enregistree, vous pouvez utiliser I'adresse 
de votre site Drupal comme OpenID a la place de http://www.openidfrance.fr/ 
gaston. 


Cliquez maintenant sur fonglet Mes identites pour specifier les informa- 
tions que vous desirez rendre visibles aux serveurs sur lesquels vous utili- 
serez votre identifiant. Au minimum, vous devez bien entendu cocher le 
nom d utilisateur et fadresse courriel. Enfin, enregistrez. 
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Mon Compte | Mes Informations | Mes Identites | Mes Sites | Mes Recherches | Aide 


> Mon OpenlD visible 

> www.wasab.dk 


Mapage personnels : http://www.openidfrance.fr/yoran 

Je veux etre invisible ? 

Type 

Information 

Status 

0 Nom d'utilisateur 

gaston 

Optionnel 

0 Email 

gaston@colchique-conseil.fr 

Optionnel 

□ Prenom Nom 


Optionnel 

□ Date de naissance 

1975-01-01 

Optionnel 

□ Genre 

Femme 

Optionnel 

□ Langue principals 


Optionnel 

□ Adresse 


Optionnel 

□ Code Postal 


Optionnel 

□ Ville 


Optionnel 

□ Pays 


Optionnel 


En registrar j 


Figure 12-32 

Vous pouvez definir 
precisement les informations 
que vous souhaitez 
faire connaTtre. 


Le parametrage de votre compte OpenlD est maintenant termine ; cli- 
quez sur Se deconnecter et retournez sur votre site Drupal pour activer 
dans la foulee le module OpenlD. Lorsque c’est fait, deconnectez-vous. 

La boite de connexion a quelque peu change et vous disposez mainte- 
nant dun lien Se connecter avec OpenlD. 

Connexion utilisateur 

Nom d' utilisateur : 


Mot de passe : 


Se connecter 
| Se connecter avec 
OpenlD 

Greer un nouveau compte 

□em ancle r un nouveau motde Figure 12-33 

P^se Votre site est maintenant compatible avec OpenlD. 


Cliquez sur ce lien pour faire apparaitre la boite de connexion specifique 
a OpenlD, dans laquelle vous allez saisir fidentifiant qui vous a ete 
donne par le site OpenIDfrance : http://www.openidfrance.fr/gaston. 
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Figure 12-34 

Formulaire de saisie de I'identifiant OpenID 


Se connecter avec OpenID ; 

n 

Qu'est-ee qu'OpenID? 

| Se connecter j, 
Annuler la connection OpenID 
Crier un nouveau compte 
Demander un nouveau motde 
passe 


Lorsque vous cliquez sur le bouton Se connecter , vous etes automatique- 
ment redirige sur votre page d’authentification OpenID. 

I OpenID 

W 1 France 

Identification OpenID 

Avant de vous authentifier avec votre OpenID sur un site, vous devezvous connecter une premiere fois avec vos identifiants 


Figure 12-35 

Saisie de votre identifiant et mot de 
passe pour activer I'OpenID 


Nom d'utilisateur 
Mot de passe 



Attention D'ou travaillez-vous ? 

Si vous utilisez cette procedure sur votre 
machine de developpement, il se peut que cela 
ne fonctionne pas correctement. En effet, votre 
machine rietant pas visible de I'exterieur, elle 
risque de ne pas pouvoir mener jusqu'au bout le 
dialogue entre les differents serveurs. 

Cette procedure est en revanche tout a fait ope- 
rationnelle pour un site en production. 


Une fois rauthentification realisee, le serveur OpenID vous demande 
quelles informations vous souhaitez rendre visibles par le serveur 
Drupal. Vous pouvez decocher ici toutes les informations qui vous sem- 
blent inutiles et choisir entre Autoriser juste cette fois et Autoriser toujours. 

Passee cette etape, vous etes renvoye sur votre site Drupal oil vous etes a 
present miraculeusement identifie, un compte ayant ete cree. 

Comme vous le voyez, OpenID est un formidable outil permettant de 
ne plus avoir a retenir des dizaines de couples identifiant/mot de passe. 


Prendre en charge les Gravatars 

A finstar d’OpenID qui permet dutiliser un seul identifiant pour tous 
les sites web prenant en charge cette norme, Gravatar permet dutiliser le 
meme avatar sur tous les sites sur lesquels vous intervenez. La difference 
est que Gravatar est une solution proprietaire et qu’elle risque un jour 
d'etre supplantee... par OpenID. Toujours est-il que cette plate-forme 
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est aujourd’hui tres appreciee des internautes, et qu’il est difficile de ne 1 

pas la prendre en compte. 

Pour tester cette fonctionnalite, vous devez d’abord creer votre Gravatar. 

Allez sur le site http://fr.gravatar.com/signup et saisissez l’adresse de courriel 
que vous souhaitez associer a votre Gravatar. 


Inscrivez-vous pour obtenir votre prop re Gravatar 

Tout ce qu'il nous faut est votre adresse e-mail. Vous recevrez par retour un courrierde confirmation incluant un lien 
pour activer votre compte, et vous permettre de choisir un mot de passe. 


Adresse e-mail: 


g aston @ool oh iqu e-oon sei I .ftj 
\ S'insorire J 


Figure 12-36 

Inscription au service gravatar.com 


Une fois inscrit, vous recevrez un courriel de confirmation a fadresse 
indiquee, contenant un lien vous permettant d’activer votre compte. 
Vous sera alors demandes votre pseudo, ainsi qu un mot de passe. 

Une fois ces informations validees, le site vous invite a Rajouter une image 
en cliquant id , ce que vous faites bien evidemment. Suivez les instruc- 
tions pour ajouter votre avatar, puis selectionnez la categorie C pour indi- 
quer que cet avatar n est pas de nature offensante (et effectivement, il ne 
doit pas l’etre !), et convient done a tous les sites. 

C’est termine, cet avatar est maintenant associe a votre adresse courriel. 
Vous avez bien sur la possibility d’aj outer d’autres adresses de courriel sur 
le meme compte avec d’autres avatars. 


Selectionner une adresse e-mail ci-dessous a modifier ou add a new email 



gaston@colohiqu0-conseil.fr 

Vous avez select ion n& cette adresse-, maintenant choississ&z une image, ci-d&ssous, a associer a cett&adr&sse 

AdressQ prinepale (ne peutetre effacee) | N'utilisez pas cette image | Verifierce Gravatar | Link 


Choississez une image, ci-dessous, a associer a Tadresse selectionnee (ci-dessus), ou 

add a new image 


Figure 12-37 

Association d'un portrait 
a une adresse courriel 



Passons a present a la mise en oeuvre de ce gravatar dans Drupal, en installant le 
module Gravatar Integration. Une fois ce dernier active, allez dans les droits 
d’acces et octroyez la permission Utiliser les gv avatars auxutilisateurs anonymes. 


URL Module Gravatar Integration 

► http://drupal.org/project/gravatar 
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La derniere etape consiste a bien verifier que vous avez active les por- 
traits utilisateur - ce qui est le cas si vous avez suivi jusqu’ici toutes les 
instructions de ce livre et que dans la configuration du theme courant, 
ces portraits sont bien affiches. 

II ne reste alors plus qua se deconnecter pour saisir un commentaire en 
utilisant Y adresse courriel du Gravatar, et tester ainsi que tout fonctionne. 


Figure 12-38 

Le Gravatar est maintenant 
integre a notre site. 


Test de gravatar 

Par Gaston (non werifiejL le ven, 06i’05i'2009 - 02:49. 

Test de gravatar 

repondre 



Bonne pratique Attention a vos adresses de courriel 

D'une maniere generale, faites attention a vos adresses de courriel. Le site Gravatar est gere 
par une societe privee et, en theorie, rien ne leur interdit de revendre a I'avenir les adresses 
courriel qu'ils ont collectees. II est done fortement conseille d'utiliser une adresse courriel spe- 
cifique que vous mentionnerez dans tous vos commentaires sur tous les sites, et que vous 
emploierez pour creer votre Gravatar. Ainsi, si d'aventure cette adresse finissait dans de mau- 
vaises mains, vous n'aurez pas compromis votre adresse principale. Creer une adresse de cour- 
riel prend environ dix secondes sur un site comme Gmail ou Yahoo!, ce qui n'est pas cher paye 
pour les inconvenients que vous pourrez eviter. 


Ajouter un formulaire de contact 

Un formulaire de contact est un element tres important, quel que soit le 
type de site que vous cherchez a developper. N’importe quel visiteur 
desirant des informations, voulant vous prevenir d un probleme, ou sou- 
haitant vous demander une precision, aura tendance a chercher un lien 
Contactez-nous dans la page sur laquelle il se trouve. 


Bonne PRATIQUE Ne pas presumer de la configuration d'un navigateur 

II peut venir a I'idee d'utiliser, au lieu d'un formulaire, un lien de type 
mailto://adresse@courriel.fr. Une telle URL entraine I'ouverture de I'editeur de courrier 
associe au logiciel de messagerie de I'utilisateur, prerempli avec I'adresse fournie. Le probleme 
de cette approche est que tous les postes clients ne disposent pas de cette fonctionnalite cor- 
rectement configuree et il arrive alors qu'un die sur ce type de liens ne provoque aucune 
action, ou pire, genere une erreur. Ce probleme est encore plus vrai lorsqu'il s'agit de termi- 
naux mobiles (telephone, PDA, etc.). 

L'option du formulaire est done a privilegier, pour etre sur de recevoir en toutes circonstances 
les messages envoyes par vos visiteurs. 
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Pour creer un tel formulaire, vous devez activer le module standard 
Contact de Drupal, qui se trouve dans la section Core - facultatif. Une 
fois cela fait, dirigez-vous vers Construction du Site puis Formulaires de 
Contact. La premiere chose a faire ici est d’ajouter une « categorie », qui 
peut etre consideree comme un type de formulaire ; pour cela, cliquez 
sur Ajouter une categorie. 

Remplissez d’abord le champ Categorie , qui servira aussi de titre au for- 
mulaire. S’agissant dun formulaire de contact general, nous prendrons 
en guise de titre « Nous contacter ». Vous devez ensuite preciser a qui les 
messages seront transmis, et pouvez saisir pour cela plusieurs adresses de 
courriel en les separant par des virgules. 

Vous pouvez ensuite saisir un message qui informera 1 utilisateur a lorigine 
du message de contact que sa demande est bien en cours de traitement 
(champ Reponse automatique ). 


Bon A savoir Un formulaire de contact 
pour vos utilisateurs 

Le module Contact ajoute aussi un formulaire de 
contact par utilisateur. Chaque utilisateur peut 
ainsi activer son propre formulaire en allant dans 
Mon Profil, dans I'onglet Modifier , puis dans la 
section Parametres de contact, en cochant 
Formulaire de contact personnel. 


Categorie : * 

|Mous contacter | 

Exemple : 'votre avis sur le site' ou 'information sur les produits'. 

Destinataii es : * 

webmast e r@c ol c hique - c onseil . f r 

Exemple : 'webmestre@votresite.com' ou 'commercial@votresite.com, support@votresite.com'. Pour entrer 
plusieurs destinataires, separez chaque adresse e-mail par une virgule. 

Reponse automatique : 

Merci pour votre message, nous le trait ons dans les plus brefs delais 

Reponse automatique optionnelle. Laissez vide si vous ne souhaitez pas envoyer a I' utilisateur un message de 
reponse automatique. 


Figure 12-39 

Creation du formulaire de contact general 


Enfin, a la fin du formulaire, vous trouverez le champ Selectionne, qui 
permet de l’instaurer comme etant le formulaire par defaut ; puisque 
c’est bien le cas ici, nous allons done selectionner Oui. Nous pouvons 
maintenant enregistrer le formulaire. Le module nous amene alors sur 
I’onglet Liste , en confirmant l’enregistrement. II est bien sur encore pos- 
sible de modifier ce formulaire ou bien d’en ajouter d’autres. 

Le formulaire de contact general est a present accessible via l’URL 
http://www.cochique-conseil.fr/contact. 

Sachant que d’un point de vue ergonomique, un utilisateur s’attend a 
trouver le lien Contactezmous soit en haut a droite de la page, soit en bas 
dans le pied de page, nous allons positionner cette nouvelle option en 
haut a droite de la page, en ajoutant pour cela un nouvel element au 
menu des liens primaires. 
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Parametres du menu 


Figure 12-40 

Ajout d'un nouveau lien primaire 
pour Contactez-nous 


Chemin : * 

(contact | 

Lb chemin de Diup al vers lequel pointe cet element de menu. Celapeut etre un chemin interne a Dru pal 
comme nodefadd ou une url externe comma http//drupal. org. E litre z <froFK> pour pointer vers la page 
d'accueil. 

Tin e du lien dans le menu : * 

| Contact ez nous j 

Texte correspond au nom du lien quisera affiche dans le menu. 

Description : 

Cliquez ici pour nous laisser un message 

La description affichee quand le pointeur survole cet element de menu. 


Une fois l’element enregistre, le lien devrait apparaitre automatiquement : 


Figure 12-41 

Le lien Contactez-nous est maintenant actif. 



Pour completer nos parametrages, nous pouvons aussi editer le bloc cree 
pour le pied de page et y ajouter un lien vers le formulaire de contact. 
Pour ce faire, nous pourrions inserer directement une balise de lien 
<A href=’ . . . ’> mais ce ne serait pas tres pertinent. En effet, comme 
nous l’avons vu dans le chapitre sur la creation dun theme, il est plus 
judicieux, pour les liens sur des chemins internes au site, dutiliser la 
fonction l(’Nous Contacted, ’ contact ’). Nous devons cependant 
activer le format d’entree PHP code, ce qui donne : 


Corps du liloc : 



® Colchique ConseiT - Tout droits reserves - <?php print 1 ( 1 Contactez-nous 1 , 
'contact') ?>- Ce site est propulse par <a href= "http: //drupal . org">Drupal</a>. 




Le contenu du bloc vu par I' util is ate ur. 

▼ Format d’entree 


Figure 12-42 

Changement du bloc Pied de page 


O Filtered HTML 

■ Les adresses de pages web et de messagerie electronique sont transformees en liens automatiquement. 

• Tags HTML autorises : <a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd> 

■ Les lignes et les paragraphes vont a la ligne automatiquement. 

• • Full HTML 

» Les adresses de pages web et de messagerie electronique sont transformees en liens automatiquement. 

* Les lignes et les paragraphes vont a la ligne automatiquement. 


® PHP code 

■ Vous pouvez errtrer du code PHP. Vous devrez inclure les balises <7php ?>. 


Une fois le bloc enregistre, vous devez obtenir le pied de page suivant. Si 
ce n est pas le cas, verifiez si une erreur s’est glissee dans fecriture de 
votre code PHP - ce qui vous montre par la meme occasion les diffi- 
cultes et les pieges d utilisation de ce filtre (pour memoire, il ne doit etre 
utilise que pour faffichage de variables ou Tappel de fonctions). 
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© Colchique Conseil - Tout droits reserves - Contacts z-nous- Ce site est propulse par Drupal. 


Figure 12-43 

Le nouveau pied de page 


Nous disposons a present de deux liens vers le formulaire de contact. II 
ne nous reste qua modifier les droits d’acces pour donner a lutilisateur 
anonyme la permission Acceder au formulaire de contact global. 

A present, nous allons pouvoir tester le formulaire en nous deconnectant 
pour observer le dispositif en conditions reelles : 

Contact 

Vous pouvez nous laisser un message en utilisant le formulaire de contact ci-dessous. 

Voire nom : * 

| R obert | 

Volie ailress e d e couniel : * 

|robert@une_s cciete.fr] | 

Objet : * 

|Demanded'information | 

Message : * 

Bonj our, 

J'aurais aims avoir plus de precisions sur vos experiences dans le domaine des. . . 

Figure 12-44 

] Envoyer u n courriei ] Un visiteur nous laisse un message. 


Une fois que le visiteur a clique sur le bouton Em/oyer un courriei , il est 
prevenu de la bonne expedition du message par Drupal. 


Votre message a ete envoye. 


Figure 12-45 

Message de confirmation d'envoi pour le visiteur 


II re^oit en outre un courriei de bonne prise en compte de sa demande. 
De votre cote, vous recevez le courriei dans votre messagerie a fadresse 
indiquee lors de la definition du formulaire. 


Ajouter un module d’impression 
et vos contenus en PDF 

II existe deux services tres apprecies par les utilisateurs se trouvant face a 
un article un peu long : la possibility d’imprimer Y article ou de tele- 
charger sa version PDF pour le lire plus tard via un outil mobile (type 
PDA, telephone, etc.). 
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URL Module Printer 

► http://drupal.org/project/print 


URL TCPDF 

► http://www.tecnick.com/public/code/ 
cp_dpage.php?aiocp_dp=tcpdf 


URL Domtopdf 

► http://www.digitaljunkies.ca/dompdf/ 


Bon A SAVOIR Creer des PDF avec WebKit 

Une troisieme possibility existe depuis peu et uti- 
lise cette fois-ci I'outil wkhtmltopdf. Cet outil n'est 
pas une bibliotheque PHP mais un petit utilitaire 
binaire qui fonctionne sous GNU/Linux et sous 
Windows. II a I'immense avantage d'etre tres 
rapide et d'utiliser le meme moteur de rendu que 
les navigateurs Safari, Google Chrome ou Kon- 
queror (WebKit). Pour de plus amples informations 
sur Installation de cet outil, consultez la page : 

► http://arnumeral.fr/node/72 


Figure 12-46 

Activation du module Printer 


Figure 12-47 

Desactivation des options intrusives 


Ces deux fonctionnalites sont prises en charge par le module Printer, qui 
permet de surcroit l’ajout sur chaque article d un lien Envoy er a un ami. 

Ce module necessite une bibliotheque PHP pour generer des documents 
au format PDF. Nous avons a fheure actuelle deux possibility : l’ancien 
projet TCPDF qui fonctionne tres bien mais souffre de fabsence de sup- 
port pour les feuilles de style, et Domtopdf qui, lui, gere les fichiers CSS 
mais ne prend en revanche pas en compte les caracteres accentues. De plus, 
Domtopdf semble etre un projet tres peu actif depuis deux ans. Pour ces 
raisons, nous allons preferer TCPDF, certes moins joli, mais plus fiable. 

Pour que la prise en charge du PDF fonctionne, vous devez aller sur le 
site de TCPDF et telecharger l’archive de la derniere version du projet 
pour PHP 5, avant de la decompresser dans le dossier du module Printer 
de maniere a y creer un sous-dossier tcpdf . 

Une fois ceci fait, nous sommes pret a activer les trois sous-modules de 
Printer, chacun correspondant a une fonctionnalite : generation PDF, 
impression et envoi par courriel. 

^ Printer, e-mail and PDF versions 


Active 

Norn 

Version 

Description 

0 

PDF 

version 

6.X-1.7 

Adds the capability to export pages as PDF. 

Depend de : Printer-friendly pages (core) (disabled) 

0 

Printer- 

friendly 

pages 

(core) 

6.X-1.7 

Adds a printer-friendly version link to content and administrative pages. 
Requis par : Send by e-mail (disabled), PDF version (disabled) 

0 

Send 

by 

e-mail 

6.X-1.7 

Provides the capability to send the web page by e-mail 

Depend de : Printer-friendly pages (core) (disabled) 


Allons ensuite parametrer ces fonctionnalites dans Configuration du site > 
Version imprimante > Courrier electronique et PDF. 

Cliquez d’abord sur l’onglet Page qui permet de parametrer fapparence 
que prendra le lien affiche pour chaque contenu : lien standard, icone, 
position, etc. Les parametrages par defaut correspondent aux usages en 
vigueur, vous pouvez done les conserver sans aucun probleme. 

En revanche, deux options interessantes se trouvent a la fin du formu- 
laire. La premiere intime au module l’ordre d’ouvrir la version impri- 
mable du contenu dans une nouvelle fenetre, ce qui n est pas une bonne 
idee, et la seconde fordre de declencher automatiquement fimpression, 
ce qui est une moins bonne idee encore, car il est toujours preferable de 
laisser ces choix a lutilisateur. Cela nous donne le parametrage suivant 
que vous pouvez enregistrer : 

□ Affiche Line version imprimable dans une nouvelle fenetre 
ActivSe, cette option ouvrira b version dans une nouvelle fe nStie/o ng let. 

I— I Envoyer a I'imprimante 

Appelle automatiquement b to notion d'imp ression du navigate u r lo rsq ue la version imprimable estafffchee. 
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Dans le second onglet, vous pouvez changer le parametrage concernant 1 

les courriels. Comme pour l’onglet precedent, la premiere partie du for- 
mulaire correspond au type de lien, que nous pouvons laisser en l’etat. A 
la fin du formulaire, vous avez la possibility de choisir de n envoyer que le 
resume du contenu par defaut (le terme « aper^u » est ici assez mal 
choisi) et de laisser a l’utilisateur le choix d’en envoyer plus. Les deux 
cases etant cochees par defaut, nous pouvons les laisser ainsi. 

Le troisieme onglet nous permet d’activer la bibliotheque TCPDF que 
nous avons installee. Normalement, le module a automatiquement detecte 
sa presence et vous la propose done comme Outil de generation PDF. II vous 
suffit done de cocher cette option, puis d’enregistrer la configuration. 


Outil de generation PDF : 

•' s ite s/al l/m o cl u I e s/c o ntri b/p ri nl/tc p cJf/tc p df . p h p Figure 12-48 

Selection de la bibliotheque TCPDF 

Cette option chnisit I'd util de generation de PDF employe parce module pourc re erla version PDF. 

Passons sur le choix du type de lien pour aller a la fin du formulaire, oil 
nous pouvons definir le traitement qui sera applique au PDF sur le navi- 
gateur client. II peut ainsi etre affiche dans la fenetre courante du navi- 
gateur, sur une nouvelle fenetre (comme pour fimpression), ou 
simplement propose en telechargement. Le dernier choix est celui par 
defaut, et e’est une bonne option car tous les navigateurs ne sont pas 
configures pour afficher correctement le format PDF au sein meme 
d une page HTML. Vous pouvez laisser tel quel le reste du formulaire 
qui correspond a des options avancees, et enregistrer la configuration. 

Le dernier onglet, Parametres, nous permet de modifier des options 
communes aux trois modes, comme fajout des « URL des versions 
imprimables », intitule peu clair signifiant simplement que vous desirez 
transformer tous les liens du contenu en notes de bas de page. 

La seconde option vous permet d ’inclure les commentaires au contenu 
genere (PDF ou impression), option qui est desactivee par defaut et que 
nous laisserons ainsi. 

Vous pouvez explorer le reste des options, qui sont simples a com- 
prendre, puis enregistrer la configuration. 

Comme nous favons fait jusque la, fetape suivante consiste a definir les 
droits d’acces sur ces nouvelles fonctions en ajoutant la permission 
Acceder a I'imprimante a 1 utilisateur identifie. 

Une fois les droits regies, vous pouvez verifier que tout fonctionne en 
voyant apparaitre sous les contenus les nouveaux liens suivants : 


» Ajo uter un commentaire | Envoyer a uii aini | Version impriinalile | version PDF 


Figure 12-49 

Les liens ajoutes par Printer aux contenus 
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Bon A SAVOIR Limiter I'impression PDF pour les utilisateurs identifies 


Savoir a quel role vous donnez le droit de generer des documents PDF ou imprimables est une 
question de ciblage de votre site. Sachez cependant que la generation de PDF n'est pas une 
operation legere et qu'autoriser les anonymes a le faire indura de facto des automates de 
recherche tel que Google. II est done preferable d'autoriser les utilisateurs anonymes a 
acceder seulement a la version imprimable du document et a I'envoi par courriel a un ami, et 
de reserver aux utilisateurs authentifies I'acces a la version PDF. 

Malheureusement, le module Printer a une maniere tres peu standardisee de gerer les droits 
sur ses fonctions. II n'est ainsi pas possible de gerer finement les permissions. L'astuce con- 
siste done a donner la permission Acceder a I'im prim ante aux utilisateurs anonymes, et 
dans I'onglet PDF, dans la section Visibility du lien, de selectionner I'option Afficher si le 
code PHP suivant retourne TRUE en saisissant le code PHP suivant : 

<?php 

global Suser; 
return $user->uid<>0; 

?> 

Le principe est d'utiliser I'objet global $user, qui represente I'utilisateur pour qui la page est 
fabriquee. Si le champ ui d de cet objet est egal a 0, il s'agit d'un utilisateur anonyme, auquel 
cas la fonction renvoie FALSE. 

Ceci etant dit, cette astuce n'est pas parfaite et ne fait que cacher le lien ; le PDF reste acces- 
sible a I'utilisateur anonyme connaissant le chemin Drupal pour generer un PDF. 


Par exemple, pour Tenvoi du contenu par courriel a un ami, nous obte- 
nons le formulaire suivant : 


Figure 12-50 

Envoi d'un article a un ami 


Accueil 

Envoyer la page par courrier electronique 

Voire ailresse de courrier 
electronic! Lie : 

Voire nom : | administrates 

Envoyer a : 


E litre z plusieurs adresses separees avec des virgules et ou ec rites sur d iff e rentes lignes. 

0l, i e,: |administrateur vous a envoy e un message a partir de Colchique 

Page to lie sent : Mon premier article 

Von e message : 


0 N J envoyer que l J aper;u 

Envoyer un courriel Effacer le formulaire | Annuler 


324 


www.frenchpdf.com 


Ajouter la notation de vos contenus 


MW 

"55 

c 

c 

© 

tj 

c 

o 


Qu’cst-ce qu’une notation de contenu ? 

Le principe general d un systeme de notation est de permettre au visiteur 
de donner un avis sur la qualite d’un contenu ou meme d un commen- 
taire. La gestion des notations doit etre etudiee avec soin, car elle peut 
etre utilisee de nombreuses manieres differentes et influe dans tous les 
cas sur l’ambiance generale de votre site. Une notation sur les commen- 
taires cachant automatiquement les contributions aux notes negatives, 
par exemple, risquerait de froisser votre public, meme si vous ne cher- 
chiez qua ameliorer la qualite de l’ensemble et surtout a reduire l’impact 
nefaste des trolls (voir chapitre 7). 

Nous etudierons ici le systeme de notation a travers une vision plus con- 
sensuelle, celle des contenus que vous publiez, et nous verrons la produc- 
tion d une liste des articles les mieux notes. 


Voting API et Fivestar 

II existe de tres nombreux systemes de notation mais tous ou presque 
utilisent le module Voting API. Ce dernier ne produit rien de visuel, 
mais fournit le cadre de base indispensable a tous les systemes de 
notation : gestion des compteurs, des sommes, des moyennes, etc. Pour 
notre exemple, nous allons confier la partie visuelle de la notation a un 
module relativement simple d’acces, Fivestar. 

Une fois les deux modules telecharges et installes, il suffit d’activer les 
options suivantes : 


URL VotingAPI et Fivestar 

► http://drupal.org/project/votingapi 

► http://drupal.org/project/fivestar 


Active 

Nom 

Version 

Description 

0 

Fivestar 

6.X-1.15 

Un widget basic (5 etoiles) permettanl de voter pour un nceud. 

Depend de : Voting API (enabled) 

Requis par : Fivestar Comments (enabled) 

□ 

Fivestar 

Comments 

6.K-1.15 

Evaluer les noeuds en laissant des commentaires. 

Depend de : Voting AFI (enabled), Fivestar (enabled) 

0 

Voting API 

6.x-2.Q-rc2 

Provides a shared voting API for other modules. 

Requis par : Fivestar (enabled), Fivestar Comments (enabled) 


Figure 12-51 

Activation des modules Voting API et Fivestar 


Comme nous allons orienter notre notation sur les contenus, nous allons 
devoir choisir et parametrer les types de contenu qui pourront etre notes. 
Dans notre cas, il va s’agir du type de contenu Article. 

Pour cela, dirigeons-nous vers le panneau de configuration, et cliquons 
sur Article. Sur ce formulaire que nous connaissons bien, vous consta- 
terez fapparition d une nouvelle section : Notations de Fivestar. La pre- 
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miere chose a faire consiste a Activer la notation Fi vesta r puis a 
selectionner le Nombre d'etoiles , a savoir 5 pour une note allant de 1 a 5 . 


<v 

£ 


Figure 12-52 

Activation de la notation pour 
les contenus de type Article 


Pour rioter ce contenu, activer Frvestarchdsssous. G 
echeant) et la notation dlnecte. 

® Activer la notation Fivestar 

Nombre d'etoiles : 



La section Options du widget permet de definir finement la maniere dont 
le controle de gestion des votes est affiche dans l’article. Nous allons 
choisir d’afficher le controle au-dessus du contenu et de le maintenir 
cache dans la version resumee du contenu : 


Figure 12-53 

Parametrage du controle prenant 
en charge la notation 


Options du widget 

Ces parametres vous perrmettent d'afficher avos clients un widg 
sera immediatement enregistree. 

Style d'affichage des etoiles : 

Afficher la valeur moyenne des votes 0 | 

Style d'affichage du texte : 

A la fois la note de I'utilisateur et la moyenne 0 | 

Afficher le titre du widget 
Z Permet aux utilisateurs d'annuler leurvote 
^ Enable feedback during vote saving and deletion 

Affichage du teaser : 

| <hidden> 0 |j 

Affichage complet du node : 

Widget cliquable au-dessus du contenu C j 


Nous pouvons maintenant enregistrer pour passer a la definition de 
fapparence visuelle de notre notation. Pour cela, rendons-nous dans 
Configuration du site > Fivestar. Dans cette section, nous pouvons choisir 
differentes presentations pour le controle de notation. 


O Pardefaut 

Default Aperyu: 




O Hearts 

Hea rtE Ape n;u : 

^ ^ 


'*■ Flames 
Flamea Apenju: 




' - ' Minimal 
Minimal Ape n;u: 


Figure 12-54 

Choix de I'apparence visuelle de la notation 


O Craft 


Ciaft Apergu: 

...♦** 


O Small 

Small Apenju: 

A 
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Une fois notre choix effectue et enregistre, nous finirons comme tou- 
jours ce travail de parametrage par un petit tour dans le panneau de ges- 
tion des droits d’acces, pour cette fois-ci ajouter la permission rate 
content au role Utilisateur anonyme. 

Ceci etant fait, deconnectons-nous pour verifier que l’ensemble fonc- 
tionne du point de vue du visiteur anonyme, et allons voir la version 
complete de farticle de bienvenue. 


Bienvenue 

Aucu vote pour I' instant. 

Bienvenue sur le site de Colchique Conseil. 

le cabinet de conseil en ressources humaine qui a I 'elhique a coeur . 

Vous trouverez sur notre site une presentation complete de la society 

d'humeur. Figure 12-55 

Bonne visite Notre article est pret a etre note ! 


Le controle de notation apparait correctement au-dessus du contenu. 
Toutes les flammes sont pour finstant grisees, indiquant qu aucun utili- 
sateur n a note farticle. II suffit de cliquer sur f une des flammes pour 
donner sa note a farticle. 


Bienvenue 

Votre notation : 4 Moyenne : 4 (1 vote) 


Figure 12-56 

Et ce sera une tres bonne note ! 


Votre vote est alors automatiquement enregistre et affiche, ainsi que la 
notation moyenne de farticle et le nombre total de votants. Si vous 
desirez supprimer votre vote, il suffit de cliquer sur le symbole juste 
avant la premiere flamme. 

Les contenus les mieux notes 

Une fois les votes mis en place, vous pourriez logiquement vous 
demander ce que fon peut en faire. Une des utilisations les plus cou- 
rantes consiste a creer une liste des articles les mieux notes, que fon 
mettra par exemple dans un bloc. 

Pour cela, utilisons de nouveau le module Views qui, outre les pages et 
les flux, est aussi capable de presenter une liste sous la forme d un bloc. 

Pour nous simplifier la tache, nous allons dupliquer encore une fois la vue 
Articles et lui donner comme nom 1 es_arti cl es_l es_mi eux_notes, puis 
completer avec la description et f etiquette de votre choix avant d’enregistrer. 
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Nous voila a nouveau dans le panneau de parametrage de la vue. Com- 
men^ons par ajouter une nouvelle relation entre le contenu et sa note. 

Si vous vous souvenez bien, une relation dans le module Views corres- 
pond a la clause JOIN d une requete SQL. Dit de maniere plus triviale, 
une relation permet de prendre en compte des caracteres lies a notre 
contenu, comme la note d’un article. Et la note d’un article, qui est prise 
en charge par le module Voting API, est bien en relation avec le noeud 
de l’article qui est, lui, gere par le module Node. 

Pour ajouter cette nouvelle relation vers Voting API, cliquez sur le sym- 
bole d’ajout dune relation, puis dans le groupe Noeud , selectionnez 
Noeud : Voting results. 


Figure 12-57 

Ajout de la nouvelle relation 


Gro Lipesj 

[ Noeud C | 

U Noeud : Individual votes 

Votes cast by users on nodes. 

101 Noeud : Voting results 

The aggregate results of votes cast on nodes. 


Une fois ce choix valide, le panneau de configuration de notre nouvelle 
relation s’affiche. Nous allons ici selectionner Aggregation function avec 
pour valeur Average (la moyenne des notes). En effet, les fonctions 
d’agregation permettent d’operer une operation mathematique sur un 
ensemble de valeurs, ici la moyenne de toutes les notes du noeud. 


Paraineties par tlefaut Configure Relation Noeud: Voting results 
Etiquette : 

[Voting results 

Intitule pour cette relation qui ne sera affiche qu'a des fins d'administration. 

□ Exiger cette relation 

Si la relation est exigee J les elements qui ne presenters pas cette relation n'appa 

i— Data filters 

For each piece of content, many pieces of voting data may be saved. L 
exactly which types should be available via this relationship, warning! 
empty may result in multiple copies of each piece of content being dis 

Type de valeur : 

No filtering 0 

Vote tag : 

No filtering 0 

Figure 1 2—58 Aggregation fuiction : 

Parametrage de la relation Average 0 

Nous pouvons mettre a jour. Nous allons maintenant ajouter un nouveau 
critere de tri pour classer nos valeurs par ordre decroissant de note. Cli- 
quez sur le symbole d’ajout de la zone des tris et selectionnez le groupe 
Voting API results. Dans la liste qui apparait, nous allons selectionner 
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Voting API results : Valeur , qui correspond a la valeur moyenne de la note 
que nous avons definie dans notre relation. 

Groiyes : 

Voting API results 0 

□ Voting API results : Function 

The aggregate function used to calculate the result. 

□ Voting API results : Horodatage 

The time the results were calculated. 

□ Voting API results : Type cle valeur 

The nature of the results in question (points, percentage, etc). 

101 Voting API results : Valeur Figure 1 2-59 

The value of an individual cast vote. 

□ Voting API results : Etiquette Ajout cl'un nouveau critere 

An optional tag to group multi-criteria results. 

Apres la validation de ce choix, nous allons pouvoir indiquer le caractere 
descendant de notre tri ( Ordre de tri). 

Parametres par defaut: Configure critere de 
Relation : 

Voting results C 

Ordre de tri : 

O Ascendant 
# Descendant 

Miseajour Annuler | Oter 


Figure 12-60 

Parametrage du tri 


Nous pouvons mettre a jour. Avant de quitter les tris, nous allons sup- 
primer Tancien critere Noeud : Date de mise a jour , qui est un reste de 
notre vue dupliquee. Cliquez sur ce critere et appuyez sur le bouton Oter. 

Nous avons besoin d’afficher une liste de titres d’article avec, pour chacun, 
un lien vers l’article correspondant. Pour changer le style de ligne, cliquez 
sur la valeur du champ Style de ligne et selectionnez Champs. 

Parametres par default Comment les lignes de cette vue doivent etre stylees 

® Champs 
O Noeud 

Vous pouvez egalement adapter les parametres pour le style de la ligne en cours en 
cliquant sur I'icdne. 

Miseajour] ] Annuler 


Figure 12-61 

Redefinition du format des lignes 


Une fois ce choix valide, validez a nouveau en laissant les parametres tels 
quels. Vous constaterez alors que le bloc Champs est devenu actif. S’il 
contient des valeurs, selectionnez chacune d’entre elles et cliquez sur 
Oter de maniere a obtenir un bloc vide. 

champs ++* Figure 12-62 

Aucun defini Suppression des champs existants 
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A present, cliquez sur le symbole d’ajout et selectionnez Noeud : litre 
puis Ajouter. Dans le parametrage du nouveau champ, supprimez le con- 
tenu du champ Etiquette et cochez Lier ce champ a son noeud puis validez. 


£ 


Figure 12-63 

Ajout d'un seul champ Titre, 
sans etiquette et lie au contenu 


Parametres par defaut: Configure chanip Noeud: Tare 
Etiquette : 


L'etiquette de ce champ, qui sera affichee aux utilisateurs finaux si le style I'exige. 

U Exclure de I'affichage 

Cochez cette case pourne pas afficherce champ mais le charg erne an moms dans la vue. Utilisez 
cette option pourne pas montrer un champ de groupement dans chaque enregistrement ou lorsque 
vous travaillez sur des themes avarices. 

U Rewrite the output of this field 

If checked, you can alter the output of this field by specifying a string of text with replacement tokens 
that can use any existing field output. 

U Output this field as a link 

If checked, this field will be made into a link. The destination must be given below. 

□ Trim this field to a maximum length 

If checked, this field be trimmed to a maximum length in characters. 

0 Lier ce champ a son noeud 

This will override any other link you have set. 


Miseajour| | Annuler | |oter| 


Pour terminer, cliquez dans les Parametres de base sur la valeur du champ 
Style pour utiliser une liste HTML (HTML List ) qui conviendra mieux 
que notre bloc, puis mettez a jour. 


Figure 12-64 

Choix d'un format de type Liste 


Parametres par defaut: Style a appliquer a cette vue 

O Grille 
® HTML List 

Non mis en forme 
Tableau 


Voila, notre vue est maintenant prete, comme nous le constatons sur 
l’aperfu en bas de page. 


Figure 12-65 

Notre bloc affiche maintenant 
les contenus tries par notation. 


« Bien venue 

* Un no uvel article 

* Etat du inarche de I'emploi pour les ingenie urs inlbrmaticiens 

* Etat du inarche de I'emploi pour les Administrate urs reseaux 


Larticle « Bienvenue » est bien en tete de liste car, pour l’instant, il est le 
seul a avoir re<;u une note. 

Notre vue est maintenant correctement parametree. Avant de pour- 
suivre, nous allons faire un peu de menage dans les affichages de la vue 
dupliquee : selectionnez Tonglet Page , et cliquez sur le bouton Supprimer 
un affichage. Renouvelez l’operation sur Tonglet Flux et enregistrez la vue. 
Les deux onglets inutiles devraient disparaitre. 
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Enfin, nous allons creer un nouvel affichage de type Bloc. Pour cela, 
selectionner Bloc dans la liste des affichages et cliquez sur le bouton 
Nouvel affichage. Ceci fait, cliquez sur l’onglet Bloc pour en changer le 
titre en « Les meilleurs notes ! », sans oublier de mettre ensuite a jour. 

Nous pouvons maintenant enregistrer notre vue, avant de nous rendre 
dans le panneau de configuration des blocs pour ajouter le bloc Les 
meilleurs notes dans la region Barre de droite. Une fois la disposition des 
blocs enregistree, le nouveau bloc devrait apparaitre. 


Figure 12-66 

Le nouveau bloc apparait dans la barre de droite. 


Les meilleurs notes 

Etatdu manche de Hemploi pour 
les ingenieurs informaticiens 
Bienvenue 

Etatdu manche de Hemploi pour 
les Administrateurs neseaux 


Pour tester son fonctionnement, vous pouvez selectionner le dernier con- 
tenu dans la liste, cliquer sur la note maximum, puis presser la touche F 5 
pour rafraichir notre bloc : ce contenu vient de passer en pole position. 


En resume 

• Les flux RSS permettent a deux logiciels d’echanger du contenu. II 
sont utilises par des lecteurs de flux RSS pour se tenir au courant des 
nouveaux conte nus (noeuds, commentaires) ou entre deux machines 
pour alimenter des planets. 

• Lutilisation des flux RSS nest pas encore suffisamment repandue 
pour se passer des notifications par courriel. 

• OpenID est une technologie permettant de centraliser fauthentifica- 
tion et les informations personnelles sur un seul service. En cas d’uti- 
lisation d un identifiant OpenID, Drupal utilise ce service pour creer 
le compte et authentifier futilisateur. 

• Les Gravatars sont des portraits associes a des adresses de courriel et 
centralises sur des serveurs que Drupal peut utiliser en lieu et place 
des portraits standards, notamment pour les utilisateurs anonymes. 

• Lensemble des modules permettant une notation de contenu utilise 
le module Voting API. 
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Automatiser les taches 
recurrentes 


De nombreuses taches repetitives reviennent a 
l’administrateur, comme la publication dun article 
en attente de validation. Drupal propose une infrastructure 
de type evenement/action pour automatiser un bon nombre 
de ces taches, et liberer ainsi du temps pour des actions 
d’administration a plus forte valeur ajoutee. Nous decouvrirons 
ici comment tout cela est possible grace a la mise en oeuvre 
d’un flux de travail {workflow), dans lequel plusieurs acteurs 
interviendront tout au long des etapes du cycle de vie 
d’un article, depuis sa creation jusqu’a sa mise en ligne. 


SOMMAIRE 

► Creer des flux de travaux 

► Automatiser vos actions 

en fonction de dedencheurs 
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Creer des flux de travaux (workflows) 

Un flux de travail (en anglais, workflow) consiste dans notre contexte a 
definir les differents « etats » d un document, ainsi qu’une serie de droits 
accordes a des roles pour passer ce document d’un etat a un autre. 

Lors de notre phase de definition du besoin, nous avons decide que 
hauteur d un article pouvait le faire passer de l’etat Brouillon a hetat 
A corriger. Le correcteur, une fois son travail realise, lui attribuera l’etat 
Corrige. Enfin, le validateur - s’il considere que le document est d un 
niveau de qualite suffisant - le fera passer a l’etat Valide. A chacune de 
ces etapes, l’acteur en charge des travaux peut retourner un document a 
son etat precedent. Le correcteur peut ainsi, avant validation, decider de 
revenir sur son travail, et repasser le statut de h article en Brouillon afin 
qu il soit revu en profondeur par hauteur. 


Figure 13-1 

Le flux de travail sur un article, 
tel que nous I'avons defini. 


j Brouillon 

© 

Auteur 


© 

Auteur 


[A corriger 


fborri ge ] 


Correcteur 


© 

Validateur 


| Val ide 

► 


II s’agit la d un exemple tres simple - voire simpliste - de flux de travail. 
Dans un cas reel, nous aurions par exemple du prevoir un etat A recor- 
riger, que le validateur utiliserait pour qualifier un contenu presentant 
encore des fautes. Toutefois, cet exemple est largement suffisant pour 
comprendre comment mettre en oeuvre ces flux de travaux avec Drupal. 

Notre premiere tache sera de creer deux nouveaux roles, Validateur et 
Correcteur, puis d’affecter ces deux roles a deux utilisateurs qui partici- 
peront aux tests, respectivement Karine et Philippe, que nous avons 
crees dans le chapitre sur la gestion des utilisateurs. 
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□ Nom d'utilisateur StatuT Roles Memlire depuis Dernier acces Operations 

* contributeur 

actif ■ validateur 4 heures 51 min il y a 4 heures 51 min modifier 

• contributeur 

□ Philippe actif t correcteur 4 heures 52 min il y a 2 min 42 sec modifier 


Figure 13-2 

Karine et Philippe, 

respectivement Validateur et Correcteur 


Drupal ne gere pas en standard les flux de travaux, aussi allons-nous ins- 
taller un nouveau module nomme Workflow pour effectuer ce travail. 
Une fois ce module en place, n activez que le premier des sous-modules : 


URL Module Workflow 

► http://drupal.org/project/workflow 


▼ workflow 


Active Nom Version 
workflow 6 x11 


Description 

Allows the creation and assignment of arbitrary workflows to node types. 
Requis par : Workflow access (enabled) 


rj, workflow . . Content access control based on workflows and roles, 
access Depend de : Workflow (enabled) 


Figure 13-3 

Les deux sous-modules Workflow... 


▼ workflow 

Active Nom Version 


0 

□ 


workflow 6.x- 1.1 


workflow 

access 


6.X-1.1 


Figure 13-4 

... et I'activation du premier sous-module 


Suite a ractivation de ce sous-module, nous devons dans la foulee modi- 
fier quelques droits en ajoutant la permission Access workflow summary 
views aux contributeurs. De plus, nous ajouterons egalement la permis- 
sion Administrer les noeuds aux deux nouveaux roles de maniere a ce quils 
puissent effectuer leur travail sur un article quils n ont pas eux-memes 
ecrit. Pour etre franc, cette option est loin d'etre parfaite puisque vous 
donnerez ainsi les droits de modification sur l’ensemble des types de 
contenu a ces roles, mais il n’y a malheureusement pas de meilleure solu- 
tion pour le moment. 

Nous pouvons maintenant creer notre premier flux de travail. Pour cela, 
il faut se rendre dans Construction du site > Workflow , puis sur longlet 
Ajouter un flux de travaux. Donnez un nom au flux, puis appuyez sur le 
bouton Ajouter un flux de travaux. 


Nom du flux de travaux : 

| Redaction d'un article] 


Ajouter un flux de travaux 


Figure 13-5 

Creation du nouveau flux de travail 


335 


www.frenchpdf.com 


13 - Automatiser les taches re< 


Drupal 6 - Concevoir et deployer ses applications 


Une fois ce nouveau flux cree, letape suivante consiste a definir les differents 
etats qu’un contenu pourra prendre en suivant ce flux de travaux. Nous com- 
mencerons par saisir Broui 1 1 ons puis nous cliquerons sur Enregistrer. 


<v 

£ 


Figure 13-6 

Creation de la premiere etape du flux 


State name : * 

| Brouillon | 

Enter the name for a state in your wo 

Poids : 

I 0 c 

In listings, the heavier states will sink 

Enregistrer 


Figure 13-7 

La liste finale des etapes du flux 


Le module nous dirige ensuite sur une liste de flux oil apparait notre flux 
Redaction d'un article , contenant letat Brouillon que nous venons de creer. 

Cliquez sur le lien Ajouter un etat pour saisir l’etat A corriger ; enregis- 
trez et renouvelez ensuite l’operation pour les etats Corrige puis Valide. 
Notre flux est a present complet. 


Workflow Operations 

Redaction d'un article Ajouter un etat Actions Modifier Supprimer 


State 

Operations 


(creation) 

A corriger 

Modifier 

Supprimer 

Brouillon 

Modifier 

Supprimer 

Corrige 

Modifier 

Supprimer 

Valide 

Modifier 

Supprimer 


Nous allons maintenant definir les roles capables d’operer les transitions d un 
etat a lautre. En cliquant sur le lien Modifier se trouvant au meme niveau que 
le libelle Redaction d'un article , vous afficherezla matrice des transitions. 

Ne vous laissez pas impressionner par cet imposant amas de cases a 
cocher qui se lit comme un tableau a double entree : en ligne sont indi- 
ques les etats d’origines, et en colonne les etats d’arrivee. A chaque inter- 
section de ligne et de colonne figure la liste des roles existants. Tout le 
jeu consiste ensuite a cocher le ou les roles ayant le droit de faire passer 
un document de l’etat d’origine a celui d’arrivee. La seule notion un peu 
deroutante est l’etat (creation) : il s’agit la d’un pseudo-etat qui n’existe 
que pour indiquer quel statut doit prendre automatiquement le contenu 
a la creation. Nous saisissons done les transitions suivantes : 

• de l’etat (creation) a l’etat Brouillon, puis de l’etat Brouillon a l’etat A 
corriger, nous cochons author (l’auteur du contenu) ; 

• de l’etat A corriger a Corrige, nous cochons correcteur ; 

• enfin, de letat Corrige a Valide, nous cochons i/alidateur. 
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De/A- Brouillon A coi i icjei Conige VaJitle 



0 

author 

□ 

author 

□ 

author 

□ 

author 


□ 

anonymous user 

□ 

anonymous user 

□ 

anonymous user 

□ 

anonymous user 


□ 

authenticated user 

□ 

authenticated user 

□ 

authenticated user 

□ 

authenticated user 

(creation) 










□ 

contritauteur 

□ 

contritauteur 

□ 

contritauteur 

□ 

contritauteur 


□ 

correcteur 

□ 

correcteur 

□ 

correcteur 

□ 

correcteur 


□ 

validateur 

□ 

validateur 

□ 

validateur 

□ 

validateur 




0 

author 

□ 

author 

□ 

author 




□ 

anonymous user 

□ 

anonymous user 

□ 

anonymous user 




□ 

authenticated user 

□ 

authenticated user 

□ 

authenticated user 

Brouillon 












□ 

contritauteur 

□ 

contritauteur 

□ 

contritauteur 




□ 

correcteur 

□ 

correcteur 

□ 

correcteur 




□ 

validateur 

□ 

validateur 

□ 

validateur 


□ 

author 



□ 

author 

□ 

author 


□ 

anonymous user 



□ 

anonymous user 

□ 

anonymous user 


□ 

authenticated user 



□ 

authenticated user 

□ 

authenticated user 

A corriger 

□ 

contritauteur 



□ 

contritauteur 

□ 

contritauteur 


□ 

correcteur 



0 

correcteur 

□ 

correcteur 


□ 

validateur 



□ 

validateur 

□ 

validateur 


□ 

author 

□ 

author 



□ 

author 


□ 

anonymous user 

□ 

anonymous user 



□ 

anonymous user 


□ 

authenticated user 

□ 

authenticated user 



□ 

authenticated user 

Corrige 










□ 

contritauteur 

□ 

contritauteur 



□ 

contritauteur 


□ 

correcteur 

□ 

correcteur 



□ 

correcteur 


□ 

validateur 

□ 

validateur 



0 

validateur 


□ 

author 

□ 

author 

□ 

author 




□ 

anonymous user 

□ 

anonymous user 

□ 

anonymous user 




□ 

authenticated user 

□ 

authenticated user 

□ 

authenticated user 



Valide 










□ 

contritauteur 

□ 

contritauteur 

□ 

contritauteur 




□ 

correcteur 

□ 

correcteur 

□ 

correcteur 




□ 

validateur 

□ 

validateur 

□ 

validateur 




Figure 13-8 

L'impressionnante matrice de passage 
pour notre flux de travail 


Notre flux de travail etant complet, nous pouvons Tenregistrer pour 
retourner sur la liste des flux. Nous allons cette fois nous interesser a la 
seconde partie de la page qui nous permet d’associer a chacun des types 
de contenu un flux. Dans notre cas, nous allons done choisir Redaction 
d'un article pour le type de contenu Article et cliquer sur le bouton Save 
workflow mapping. 


o 


Content Type 

Article 


workflow 


Redaction d'un article C 


Display workflow Form for: 

0 Post 

□ Commentaire 


Billet <Aucun> o] ® Post Figure 13-9 

J commentaire Affectation du flux au type de contenu Article 


Notre flux est maintenant operationnel et pret a etre teste. 
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Pour cela, nous devons d’abord nous deconnecter, puis nous reconnecter 
en tant que Marine pour creer un type de contenu Article. Comme vous 
le constatez, le formulaire ne change en rien nos habitudes. Marine peut 
saisir son contenu et le valider comme a l’accoutumee. 


Creer ■Article' 

Titi e : * 

[ U n article dans le flux 


Domaines de Competences : * 


Ressources Humaines 


-Recrutement 


-Bilans de competence 


Sy st ernes d' inform at ion 


-Sy st ernes et reseaux 


-Assistante a maitrise d'ouvrage 


-Ingenierie Icgiciel 

_ 


Figure 13-10 

Creation d'un article 


Corps : 


B I U ABC I- 

« © 

... a publier. ..| 



Si nous jetons un coup d’oeil sur le menu de navigation Marine , nous cons- 
tatons la presence d un nouveau menu Workflow summary. Cliquez dessus 
pour faire apparaitre une liste de contenus comme celle dont nous dispo- 
sons dans Gestion des contenus , mais notez cette fois la presence dune 
colonne indiquant le tat de chacun des documents. Dans la liste Current 
State , selectionnez letat Brouillon et cliquez sur le bouton Appliquer. 


Workflow summary 

Summary Attente d'envoi 

C urrent State Content Type 

Redaction d'un article: Brouillon C <Any> C 

1 1 1 1 | Appliquer 

Figure 13-11 Current state Titre Type 

Le liste des contenus a I etat Brouillon Redaction d'un article: Brouillon Un article dans leflux Article 


Nous retrouvons ici l’article que Marine vient de creer, qui se trouve en 
toute logique dans l’etat Brouillon. Nous allons a present passer cet 
article au correcteur et pour cela, cliquez sur le lien Un article dans leflux , 
puis sur l’onglet Workflow. 

L’onglet Workflow a ete ajoute par le module du meme nom pour per- 
mettre a Tutilisateur de changer l’etat d un document, dans la limite des 
droits qui lui ont ete attribues. En l’occurrence, Marine, en tant que 
Contributeur, a uniquement le droit de passer l’article a l’etat A corriger, 
en ajoutant eventuellement un commentaire avant de cliquer sur le 
bouton Soumettre. Si Marine clique a nouveau sur Tonglet Workflow , elle 
constatera qu aucune autre action ne lui est autorisee. 
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Un article dans le flux 

Voir Modifier Workflow 
Current state: Brouillon 

Changer I'etat tie Redaction d r un article : 

* Brouillon 
O A corriger 

Commentaiie : 


Un commentaire a integrer dans le journal du flux de travaux 

Soumettre 

Historique du flux de travaux 

Dale Ancien etat Nouvel etat Par Commentaire 

ven, 06/26/2009 - 01:12 (creation) Brouillon Marine 


Figure 13-12 

Passage de Particle a I'etat A corriger 


Un article dans le flux 

Voir Modifier Workflow 
Current state: A corriger 

Historique du flux de travaux 

Dale Ancien etat Nouvel etat Par Commentaire 


ven, 06/26/2009 - 01:31 Brouillon 

A corriger 

Marine 

ven, 06/26/2009 ■ 01:31 (creation) 

Brouillon 

Marine 


Figure 13-13 

Historique des passages d'etat 


Deconnectons-nous et reconnectons-nous en tant que Philippe, qui a le 
role de Correcteur. La premiere action effectuee par Philippe sera d’aller 
lui aussi sur son lien Workflow summary pour collecter tous les articles a 
I’etat A corriger. 

II clique lui aussi sur le lien Un article dans leflux , puis sur l’onglet Modi' 
fier pour effectuer ses corrections. Une fois cela fait, il clique sur l’onglet 
Workflow. Notez alors revolution de l’historique des flux de travaux. 

Philippe peut maintenant selectionner I’etat Corrige et cliquer sur le 
bouton Soumettre. Vient alors le tour de Karine, qui possede le role Vali- 
dates et effectuera les memes operations pour cette fois-ci passer le 
document a I’etat Valide. 

Le flux etant a present acheve, l’administrateur peut alors collecter les 
articles a I’etat Valide et changer leur statut en Publie et Promu en page 
d'accueil. L’article est enfin visible aux yeux de tous. 
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Principe de fonctionnement 

La gestion des flux que vous venez d’experimenter permet d’effectuer un 
travail collaborate efficace, en fluidifiant le processus de traitement d un 
document entre les differents intervenants. 

II reste cependant un aspect aga^ant car peu optimal : pourquoi l’admi- 
nistrateur doit-il effectuer cette tache repetitive et sans valeur ajoutee, 
consistant a publier un contenu qui vient d'etre valide ? Fort heureuse- 
ment, cette action peut etre automatisee grace a deux modules integres a 
Drupal : Action et Trigger. Ces derniers n etant pas actives par defaut, 
vous devez le faire des a present. 

• Le module Action vous fournit la possibility d’effectuer un certain 
nombre d’actions, comme envoyer un courriel, changer l’etat d’un 
contenu, publier un contenu, supprimer un commentaire, etc. 

• Le module Trigger vous permet d’associer un declencheur - c’est-a- 
dire un evenement dans le systeme Drupal - a une action donnee. Par 
exemple, si nous desirons envoyer un courriel a l’auteur d’un contenu 
des qu’un nouveau commentaire apparait, nous allons associer le 
declencheur « enregistrement d’un nouveau commentaire » a faction 
« envoyer un courriel ». Le module Trigger fournit ainsi en standard 
une vingtaine de declencheurs qu’il est possible d’associer a autant 
d’actions fournies par le module Action. 

Plus interessant encore, les autres modules peuvent a leur convenance 
fournir a ces deux modules de nouvelles actions et de nouveaux declen- 
cheurs. C’est bien evidement le cas du module Workflow, et pour illus- 
trer notre propos, prenons ce probleme d’automatisation du passage au 
statut Publie d’un contenu venant d’etre valide. 

Creation d’une action simple 

Pour creer ce comportement, nous devons trouver le bon declencheur. 
Pour cela, allez dans Construction du site , puis Declencheurs (voir 
figure 13-14). 

Vous etes ici dans le centre dissociation des declencheurs connus du 
module Trigger avec l’une des actions fournies par le module Action. 
Chaque onglet represente une categorie de declencheurs particuliers. 
Cliquez sur l’onglet Workflow. 
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Commentaires Content Cron Simplenews Taxonomie UR-API Utilisateurs Workflow 

Les declencheurs sont des evenements systemes, comme par exemple quand un nouveau contenu est ajoute ou qu'un utilisateur s'identifie. Le 
module Trigger permet de combiner ces declencheurs avec des actions (taches qui executant des fonctions), comme par exemple 'retirer un 
contenu publie' ou 'envoyer un email a I 'ad mini strate u r'. La page de reglage des actions liste les actions disponibles et permet de creer et de 
configurer des actions supplementaires. 

Vous pouvez ci-dessous associer des actions a des declencheurs lies aux contenus. Vous pouvez par exemple envoyer un email a 
I'administrateur lorsqu'un contenu est cree ou mis a jour. 

[plus d'aidE...] 

Declencheur : Lots de I'enregistrement ou de la mise ajour d'un contenu 

Ghoisir une action C 1 1 Associer 


Declencheur : Apres I'enregistrement d'un nouveau contenu 

| Ghoisir une action 0 j j Associer 


Declencheur : Apres la mise ajour d'un contenu existant 

| Ghoisir une action C 1 1 Associer 


Declencheur : Apres la suppression d'un contenu 

j Ghoisir une action C 1 1 Associer 


Declencheur : Lorsqu'un contenu est affiche par un utilisateur identifie 

Ghoisir une action C 1 1 Associer 


Figure 13-14 

La liste des declencheurs 
disponibles 


Declencheurs 

Commentaires Content Cron Simplenews Taxonomie UR-API Utilisateurs Workflow 

Use this page to set actions to happen when transitions occur. To configure actions, use the actions settings page. 

Declencheur: When story moves from Redaction dun article: (creation) to Redaction dun article: Brouillon 

Ghoisir une action C 1 1 Associer | 

Declencheur: When story moves from Redaction dun article: Brouitlon to Redaction dun article: A corriger 
Ghoisir une action C | j Associer | 


Figure 13-15 

Les declencheurs specifiques aux 
flux de travaux 


Declencheur: When story moves from Redaction dun article: A corriger to Redaction dun article: Corrige 
Ghoisir une action C 1 1 Associer | 


Declencheur: When story moves from Redaction dun article: Corrige \o Redaction dun article: Vaiide 
Ghoisir une action 


C | j Associer J 


Nous trouvons ici l’ensemble des changements d etat de notre flux de tra- 
vail Rediger un article, avec dans cette liste le declencheur qui nous 
interesse : When story moves from Redaction d’un article: Corrige to Redac - 
tion d'un article: Vaiide (litteralement, « lorsquun article passe de letat 
Redaction d un article : Corrige a l’etat Redaction d un article : Vaiide »). 


www.frenchpdf.com 


341 


Dans la liste Choisir une action , nous allons selectionner, sous la categorie 
Node, Publier le contenu, puis cliquer sur le bouton Associer. 


Figure 13-16 

Ajout d'une action au declencheur 
Passage de I'etat Corrige a Valide 


Figure 13-17 

II est possible d'ajouter plusieurs actions 
a un meme declencheur. 


Figure 13-18 

Notre contenu a bien ete automatiquement 
publie et promu en page d'accueil. 


Declencheur: When story moves from Redaction dun article: Corrige to Redaction dun article: Vatide 


| Choisir une action 0 

Associer 

Choisir une action 

comment 

Retirer le commentaire 

llflodta 


article: Corrige to Redaction dun articfe: Brouilfon 

| Associer 

Publier le contenu 

Retirer le contenu de la publication 

Mettre en lumiere le contenu 

Retirer le contenu de la mise en lumiere 
Promouvoir le contenu en page d'accueil 

Retirer le contenu de la page d'accueil 
Enregistrer le contenu 

Changer I'auteur du contenu 

Change workflow state of post to next state 

user 

Bloquer cet utilisateur 

Bannir I'adresse IP de I'utilisateur courant 

simptenews 

Send pending simplenews newsletters 

article: Valide to Redaction dun article: Corrige 

| Associer 



Renouvelez Toperation avec cette fois Promouvoir le contenu en page 
d'accueil. 


Declencheur: When story moves from Redaction dun article: Corrige to Redaction dun article: Valide 


Nom 

Operation 


Promouvoir le contenu en page d'accueil 

supprimer 1 'association 


Publier le contenu 

supprimer I'association 


Enregistrer le contenu 

supprimer I'association 


Choisir une action 


rJ 


Notre association est maintenant complete. Nous pouvons la tester en 
recreant un nouvel article puis en Temmenant jusqua son etat Publie 
pour constater que son statut aura effectivement change. Sans aucune 
intervention de Tadministrateur, l’article sera en page d'accueil. 


^ Options de publication 

0 Publie 

0 Promu en page d'accueil 
U Epingle en haut des listes 
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Creation (Tune action avancee 

Dans le meme cas de figure, en supposant que Philippe est le seul cor- 
recteur de l’equipe, il peut etre judicieux de le prevenir par courriel 
lorsqu un nouveau contenu doit etre traite. L’ennui est que vous ne trou- 
verez pas d’action intitulee « Envoyer un courriel a Philippe ». 

II nous faut done la creer nous-meme, et pour cela nous rendre dans Confi- 
guration du Site > Actions. Le module Action nous donne sur cette page 
lensemble des « actions simples », e’est-a-dire ne necessitant pas de para- 
metrage. Nous y retrouvons les deux actions que nous venons d utiliser. 

Laspect le plus interessant se situe a la fin de la page, ou vous disposez 
de la possibilite de creer une « action avancee ». 


Rendre une nouvelle action avancee disponible 


| Choisissez une action avancee 0 

| Greer | 

Choisissez une action avancee 

Retirer les commentaires contenant ce(s) mot(s) cle(s)... 

Changer I'auteur du contenu... 

Retirer de la publication les contenus contenant le ou les mots cles... 
Afficher une message a I'utilisateur... 


Envoyer un courriel... 


Redirection vers une URL... 

Envoyer le bulletin... 

Abonne I'utilisateur a un bulletin... 

Desabonne I'utilisateur a un bulletin... 

Change workflow state of post to new state... 



Figure 13-19 

Selection d'un action complexe 
et done parametrable 


Dans cette liste, nous trouvons Envoyer un courriel. Selectionnez cette 
action et appuyez sur le bouton Creer. Cela nous mene a un formulaire 
dans lequel vous pouvez specifier une description, un destinataire, fobjet 
du courriel et le corps du message. Saisissez les elements suivants : 


Description : 

[Notification a Philippe d'un nouveau contenu acorriger ] 

□eserption unique pour cette action avancee. Cette desorption seraaffichee avec les actions ■ 

Declencheur. 

Destinataire : 

[philippe@colchique-conseil.fr ] 

L'adresse de labolte aux lettres e lectio n iq ue a laquelle le message doit etre envoys OU entre 
original. 

Objet: 

[iJn nouvel article est acorriger ] 

Sujetdu menage. 

Message : 

Vous pouvez Hediteren cliquant sur le lien suivant : 

%node_url 

Figure 13-20 

Bonne joumee Parametrage de Taction Envoyer un courriel 
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Figure 13-21 

Notre nouvelle action est maintenant 
integree parmi les autres. 


Figure 13-22 

Association du dedencheur Brouillon vers A 
corriger avec notre action 


Figure 13-23 

faction est maintenant associee. 
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Rien d'extraordinaire dans ce message mis a part la variable %node_url 
qui sera automatiquement remplacee par l’URL pointant vers le contenu 
a corriger. Une liste de ces variables est visible sous la zone d'edition. 
Cliquez sur Enregistrer, et voila votre nouvelle action disponible. 


node 

Change workflow state of post to next state 

simplenews 

Send pending simplenews newsletters 

system 

Notification a Philippe d'un nouveau contenu a corriger configurer suppiimer 

user 

Bloquer cet utilisateur 


Vous pouvez bien evidemment supprimer ou modifier la configuration de 
cette nouvelle action, mais ce nest pas necessaire dans le cas present. 
Retournons alors sur la page dissociation des declencheurs dans notre 
onglet Workflow pour associer cette nouvelle action avec le changement 
d'etat Brouillon vers A corriger. 


Dedencheur: When story moves from Redaction dun article: Brouillon to Redaction dun article: A corriger 


Notification a Philippe d'un nouveau contenu a corriger 


0 j i Associer 


II suffit des lors de cliquer sur Associer pour activer la nouvelle regie, et 
permettre a Philippe de recevoir son courriel sans avoir a ecumer la page 
Workflow summary. 

De la meme maniere, nous pouvons creer une action avancee « Envoyer 
un courriel a l’auteur d'un contenu lorsqu'un commentaire y est publie ». 
Le travail a effectuer est identique a celui que nous venons de realiser, a 
la difference pres que l'adresse de destination sera cette fois-ci %author. 

Quant au dedencheur, vous le trouverez dans l'onglet Commentaires sous 
le nom de Apres I’enregistrement d'un nouveau commentaire. II ne vous 
reste plus qu'a creer l'association puis ajouter un commentaire sur un 
article afin de verifier que Marine rec^oit bien sa notification. 


Dedencheur : Apres I'enregistrement d'un nouveau commentaire 
Nom Operation 

Envoyer un courriel a I'auteur d'un contenu lorsqu'un commentaire y est publie supprimer l'association 
| Ghoisir une action 0 1 1 Associer || 


Ne vous etonnez cependant pas si Marine refoit deux messages, car nous 
venons par cette association de mimer purement et simplement le fonc- 
tionnement du module Comment notify que nous avons active lors du 
chapitre precedent... 
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Modules MAGIQUES Creer des regies conditionnelles 

Les modules Action et Trigger permettent de faire enormement de choses mais restent malgre 
tout limites par I'absence de conditions. II n'est par exemple pas possible de creer une associa- 
tion entre le dedencheur « Un contenu a ete modifie » et Taction « Envoyer un courriel a 
I'auteur du contenu » avec la condition « si le statut du contenu est passe a Modifie ». 

Si vous avez besoin de ce genre d'action, vous devez regarder de pres le jeune module Rules 
qui a pour objectif de remplacer les modules Workflow, Action et Trigger par un un systeme de 
regies evoluees. 

► http://drupal.org/project/rules 


En resume 

• Le module Workflow permet de creer des flux de travaux et de les 
associer a des types de contenu. 

• Le module Action vous fournit des actions pretes a l’emploi, ainsi 
que la possibility de creer des actions complexes. De nombreux 
modules ajoutent de nouvelles actions. 

• Le module Trigger a pour role de fournir une liste d evenements et de 
vous permettre d’associer une serie d’actions a un evenement donne. 
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Ecrire son premier module 


Une des grandes forces de Drupal reside dans son architecture 
fondee sur des modules. Que ce soit pour la gestion des blogs 
ou celle d’un forum, chaque fonction fondamentale est en 
realite un simple module interagissant avec le coeur de Drupal. 
Si les modules fournis en standard ne suffisent pas, nous 
l’avons a present bien assimile, des milliers d’autres sont 
disponibles et couvrent a peu pres tous les usages. Malgre cette 
richesse, il arrive cependant que Ton ne trouve pas le module 
correspondant parfaitement a notre besoin. Pourquoi alors 
ne pas le fabriquer soi-meme et decouvrir ainsi comment 
Drupal s’adapte facilement a toutes les situations ? 


SOMMAIRE 

► Comprendre la structure 
d'un module 

► Cerner le fonctionnement 
d'un module au sein de Drupal 

► Creer et activer son premier 
module 
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Prerequis 

Les seuls prerequis pour developper un module sont une bonne connais- 
sance des concepts cles de Drupal (blocs, types de contenu, contenus, taxo- 
nomie, etc.) ainsi qu une relative maitrise de PHP et des bases de donnees. 

Armes de tout cela, nous allons commencer en douceur avec la creation 
d un module dont le but sera de modifier a Y affichage tous nos noeuds 
pour y ajouter un petit message. Ce chapitre a pour but de vous montrer 
les possibilites qui vous sont offertes et de vous permettre de prendre 
conscience que la creation de modules est une alternative simple a mettre 
en oeuvre. Meme si vous ne les developpez pas vous-meme, savoir com- 
ment ils fonctionnent et comment ils sont structures permet d’eviter de 
commettre ferreur classique d un trop grand volume de code dans le 
theme alors quil aurait parfaitement sa place dans un module autonome 
et facile a manipuler. 


Pourquoi faire son propre module ? 

Contrairement a d’autres CMS du marche, Drupal est modulaire « a la 
racine », et ceci depuis ses debuts. Nous sommes loin d un systeme qui 
s’apparenterait a des greffons mais plus proche d une architecture de type 
microkernel. Comme les systemes d exploitation de ce type, Drupal charge 
lors de sa phase de demarrage fensemble des modules actives en memoire 
et les laisse communiquer entre eux pour effectuer une tache donnee. 


Figure 14-1 

Fonctionnement interne 
des modules de Drupal 


/ 

Navigateur 


1 


i 

L 1 


k. 

Noyau Drupal 



| theme j | cac he J [ database J | etc . [ .image I 

Fonctions communes 
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Ainsi, comme nous l’avons vu, la grande majorite des fonctions CMS de 
Drupal sont a la charge des modules, y compris les fondamentaux 
comme la gestion des noeuds, des commentaires, des flux RSS, etc. 
Comme un systeme d’exploitation standard, le noyau et les modules dis- 
posent d un ensemble de fonctions specialises et groupees par famille 
(cache, courriels, transactions HTTP, images, etc.), permettant d’acce- 
lerer le developpement en evitant la duplication de code, et done de 
diminuer le nombre d’erreurs. 

Une fois le travail acheve, lorsque la page HTML est produite, le noyau 
Drupal va eteindre puis decharger chacun des modules actifs, pour fina- 
lement lui-meme s’arreter. A ce stade, la difference avec un systeme 
d’exploitation classique est que Drupal effectue ce cycle demarrage/ 
chargement/traitement/dechargement/arret pour chaque page fabri- 
quee. On comprend alors mieux l’importance de ne pas activer plus de 
modules que necessaire car leur temps de chargement et dechargement 
s’additionne au temps de generation de toutes les pages affichees. 

Dans ce type d’architecture, la nature distribute des traitements entraine 
un fort volume d’echanges entre modules. Ce point constitue generale- 
ment le goulot d’etranglement pour les performances des systemes a base 
de micronoyaux. Avec Drupal, le probleme est regie simplement et effi- 
cacement par l’utilisation de fonctions PHP. II n’y a done plus aucun 
inconvenient particulier dans cette approche, et le fait que Drupal soit 
l’un des CMS les plus veloces de sa categorie n’est en cela pas anodin. 

Toujours est-il que cette approche « modulaire » depuis l’origine a eu 
pour resultat une extreme richesse des fonctions que les modules peu- 
vent exploiter. Contrairement aux CMS qui utilisent une vision 
« greffons » et qui prevoient des points d’attache possibles, Drupal n’est 
au fond que points d’attache. II est ainsi tres rare de ne pas pouvoir 
modifier son comportement par un module correctement developpe. 

En resume, les modules etant un des grands atouts de ce CMS, il serait 
dommage de se limiter aux creations des autres tant il est facile de fabri- 
quer les siens, totalement adaptes a ses besoins. Pour aller plus loin 
encore, tous les modules de Drupal etant sous licence GPL, savoir com- 
ment fabriquer un module revient aussi a savoir comment le modifier 
pour recuperer par exemple la fonction qui vous interesse, plutot que 
d’embarquer l’usine a gaz au grand complet... 
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Figure 14-2 

Fonctionnement des hooks de module 



node. module 


Un module Drupal n est rien d’autre qu’un bout de code PHP que Ton 
peut activer ou desactiver a volonte et dont le seul role est d ’interagir 
avec les autres modules de Drupal. 

Les interactions entre modules se font sur un mode participatif. En 
effet, l’idee fondamentale est qu’au cours dun de ses traitements, un 
module peut demander a d’autres modules une contribution. 

Pour mieux comprendre, prenons un exemple. Comme nous le savons 
deja, le module qui gere les conte nus (noeuds) s’appelle Node. Un de ses 
roles consiste a transformer un contenu stocke dans la base de donnees 
en un contenu affichable en HTML. Une des etapes de ce traitement 
consiste a ajouter les liens qui se trouvent sous le contenu (repondre au 
commentaire , afficher la version imprimable , etc.). 

Le module Node, au moment de creer la liste des liens, demande a tous 
les modules si lun d’eux a un lien a ajouter. Un des modules qui 
repondra present est le module Comment ; il gere les commentaires et 
inserera done le lien Ajouter un commentaire. De meme, le module Print 
lui aussi repondra pour ajouter a son tour les liens version PDF , version 
imprimable et envoyer a un ami. Et ainsi de suite. 

Pour reussir a mettre en oeuvre cette collaboration, Drupal a introduit, 
comme pour les themes, le concept de hook (en fran^ais crochet). Chaque 
module peut ainsi declarer un nombre arbitraire de hooks disponibles pour 
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les autres modules qui sont generalement decrits dans sa documentation. 
Dans notre exemple, le hook propose par le module Node s’appelle Link 
et tous les modules qui veulent repondre a ce hook declareront une fonc- 
tion dont le nom sera compose du nom du module suivi du nom du hook, 
link, separes par un caractere souligne. Ainsi, le module Comment et le 
module Print ont tout deux implements une fonction comment_link et 
pri nt_l i nk. Une telle implementation ressemblera a ceci : 

Un exemple d 1 implementation de hookjink 

function comment_l ink($type , $node = NULL, $teaser = FALSE) { 

$1 i nks=array() ; 

return $links; 

} 

Lorsque le module Node aura besoin de la participation des autres 
modules pour aj outer ses liens, il va simplement demander a Drupal de 
prendre chaque nom de module active pour regarder s’il existe une fonc- 
tion composee de ce nom suivi de _link. Ensuite, Drupal appellera ces 
fonctions les unes apres les autres. Du cote du module Node, cet appel 
va done ressembler a ceci : 

Exemple d’invocation de toutes les implementations de hook_l i nk 

$node->links = invoke_all ( ‘ 1 i nk’ , $node, $teaser) ; 

i nvoke_al 1 est la fonction de Drupal qui ira chercher les hooks de type 
link dans tous les modules actives puis appeler ces fonctions 1 i nk - si elles 
existent - avec les parametres qui sont donnes. A ce titre, cette fonction 
ressemble beaucoup a la fonction theme () que nous avons deja abordee. 

Chaque module fournira ainsi son tableau de liens que Drupal va agreger 
pour fournir au module Node un seul tableau contenant tous les liens. 

Cependant, qui dit appel de fonction dit parametres. II ne suffit done 
pas de connaitre le nom du hook pour pouvoir fimplementer, encore 
faut-il savoir quels parametres le module fappelant va nous transmettre. 
Pour cela, il faut lire la documentation de Drupal, ou pour aller plus vite, 
il est aussi possible de saisir dans votre moteur de recherche hook_ suivi 
du nom du hook, par exemple hook_block. Faites cependant attention a 
bien selectionner l’onglet correspondant a votre version de Drupal, car 
d une version a fautre, les parametres et les hooks eux-memes peuvent 
changer. 


Bon A SAVOIR Google a la rescousse 

Une astuce toute simple pour avoir la documenta- 
tion d'un hook particulier est de saisir sa reference 
dans Google (ex : hook_menu) et d'utiliser le 
bouton j'ai de la chance. Cela vous menera a 
tous les coups a la documentation de Drupal. 
Faites cependant attention a I'onglet selectionne ; 
les API changent avec la version, selectionnez 
done bien celui correspondant a la version sur 
laquelle vous travaillez. 


URL Documentation de Drupal 

► http://api.drupal.org/api/group/hooks 
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Organisation generate 

Un module est done un fournisseur d’implementation de hooks. Par conse- 
quent, la majeure partie de son code s msere dans les traitements d un autre 
module, et done au final, de Drupal, pour en etendre le comportement. 

De maniere plus prosaique, un module est simplement un dossier, 
comme un theme, qui doit porter le nom du module, ici mon_module, et 
qui doit etre place dans le dossier sites/all/modules/mes_modules. 

A l’interieur de celui-ci, vous devez avoir au minimum deux fichiers por- 
tant le meme nom de base que le dossier parent : mon_module.info et 
mon_module. module. Comme nous le verrons plus loin, le premier fichier 
contient des informations sur le module (comme pour le theme), le 
second son code PHP (un peu comme tempi ate . php). 

Le fichier de description du module 

Le fichier mon_modul e . i nfo est un simple fichier texte contenant des 
informations sur le module comme son nom, sa description, la version 
de Drupal avec laquelle il est compatible, etc. Ce qui nous donne pour 
notre exemple, le contenu suivant : 

Le fichier mon_module.info 

name = "Mon Module" 

description = "Un exemple simple de module." 

package = "Mes Modules" 

project = "mon_module" 

version = "6.X-1.0" 

core = 6.x 

• package indique dans quelle categorie le module doit etre affiche sur 
la page d’administration des modules. 

• name et description sont des informations textuelles qui seront affi- 
chees dans le panneau d’administration des modules, name reprend le 
nom du module (qui est aussi le nom du dossier). 

• version indique la version du module. C’est d’ailleurs plus une 
norme qu’ autre chose, qui se lit « Module version 1.0 pour 
Drupal 6.x ». 

• core previent Drupal que le module est seulement compatible avec sa 
version 6.x. Toute autre version de Drupal empechera le module de 
s’activer. 

www.frenchpdf.com 


Si nous avions eu besoin de definir une dependance avec un autre 
module, nous aurions ajoute une clause de la forme dependenci es [] = 
autre_module. Enfin, si vous desirez ajouter des commentaires, il suffit 
d’utiliser le symbole ; suivi du texte du commentaire. 


Le code du module 

Le second fichier est le code PHP du module. C’est lui qui hebergera les 
hooks que nous souhaitons implemented Pour l’instant, nous allons faire 
simple et n’en mettre aucun. Notre fichier contiendra done une simple 
balise de demarrage de code PHP : 

Le fichier mon_module.module pour I’instant reduit au minimum 

<?php 

Nous avons maintenant un module complet et certes inutile, mais que 
Drupal est cependant capable de voir et d’activer. Pour s’en convaincre, il 
suffit d’aller faire un tour dans radministration des modules pour le voir 
apparaitre dans la liste. 


▼ Mes Modules 

Active Nom Version Description 

□ Mol-juie G.x-1.0 Un exemple simple de module. 


Figure 14-3 

Activation de notre module 


Bon A SAVOIR Les normes de codage 

Vous aurez surement remarque que la balise PHP 
n'est pas fermee ici. Tout d'abord sachez que la 
fermeture de cette balise est optionnelle (http:// 
fr3.php.net/basic-syntax.instruction-separation). 
Mais elle est surtout deconseillee pour la redaction 
de code Drupal, car son utilisation peut induire des 
lignes blanches non voulues qui seront inserees 
dans flux de sortie. Comme le code des modules 
est insere avant toute autre execution, cela aurait 
pour effet d'empecher Drupal d'ecrire la definition 
des en-tetes HTTP et provoquerait une erreur. 

Pour plus d'informations sur les normes de codage 
utilisees au sein du projet Drupal : 

► http://drupal.org/coding-standards/ 


Vous constaterez que les informations affichees sont les champs name et 
descri pti on de notre fichier mon_modul e . i nfo. 

A ce stade, nous pourrions activer notre module mais ne le faites pas tout 
de suite : nous avons encore quelque chose a ajouter. 


Implementation d’un hook 

Ce module a pour seul but de nous permettre de comprendre comment 
tout cela fonctionne, aussi fidee nest pas de le doter d un comportement 
extraordinaire. Nous allons simplement utiliser le hook Link du module 
Node dont nous parlions plus haut de maniere a ajouter a chaque noeud un 
nouveau lien modifier qui permettra d’editer le contenu du noeud courant. 

Comme nous favons vu, le hook Link est defini de la maniere suivante 
dans la documentation de Drupal (http://api.drupal.org/api/function/hook_link) : 

La structure d'appel de hookjink 

hook_l i nk($type , $object, $teaser = FALSE) 
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Ce qui veut dire que nous allons devoir aj outer a notre fichier 
mon_module. module une fonction definie comme ceci : 

Notre implementation de hookjink 

function mon_modul e_l i nk($type , Sobject, $teaser = FALSE) { 

} 

Notre implementation du hook etant nommee <nom du module>_{nom du 
hook}, Drupal la reconnaitra lorsque le module Node aura besoin de 
l’appeler. 

Meme si ce n est pas le principal sujet de ce chapitre, signalons que ce 
hook est tres pratique pour ajouter de nouveaux liens sous les contenus, 
mais aussi sous les commentaires. En effet, le parametre $type permet de 
faire la distinction entre les types de lien demandes : $type== ' comment ' 
ou $type==' node ' . Le second parametre $object sera done soit un 
noeud, soit un commentaire selon la valeur de $type. Ici, e’est le type 
' node ' qui nous interesse. 

Le dernier parametre permet quant a lui de decider si Ton souhaite 
placer le lien sous le contenu dans sa forme resumee ($teaser==TRUE) - 
par exemple sur la page de garde du site ou dans sa forme complete. 
Nous avons a present tout ce qu’il nous faut pour ajouter un lien a tous 
les contenus. 

Le contenu de mon_module.module 

<?php 

function mon_module_l ink($type , Sobject, $teaser = FALSE) { 

// Seulement si 1 ' uti 1 i sateur a les droits d ' admi ni strati on 
if ( ! user_access("admi ni ster site configuration")) { 
return ; 

} 

SI i nks = array () ; 

// Si I'objet est un node 
if (Stype == 'node') { 

// On ajoute un nouveau lien 

$1 inks['editer-node'] = array ( 

'title* => t(' Edit ') , 

'href' => "node/" . $object->nid . "/edit" 

); 

} 

// On renvoi e les liens au module Node 
return Slinks; 

} 
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La premiere chose que nous faisons ici est de verifier que lutilisateur a bien 
le droit de modifier le contenu. Si nous ne l’avions pas fait, le lien aurait ete 
visible y compris pour les visiteurs anonymes. Meme si ces derniers abouti- 
raient sur une erreur « acces interdit », cela ne serait pas tres elegant. 

Ensuite, apres nous etre assure que la demande vise bien un noeud 
($type=='node'), il suffit de creer un tableau associatif dont le contenu est 
une serie de tableaux representant chacun un lien. Ici, nous nen avons qu un 
mais rien nempeche den mettre plusieurs. Dans tous les cas, c est Drupal 
qui se charge de transformer ce tableau en la balise <A href=" . . . 

Notez que Ton ne met pas de slash au debut de l’attribut href. Ceci 
permet a Drupal de choisir lui-meme la meilleure representation pos- 
sible pour TURL et d’opter pour un eventuel alias. 

Notez enfin fattribut title qui, comme son nom findique, contient le 
titre du lien. Vous y retrouvez l’utilisation de la fonction t( . . . ) qui va tra- 
duire la chaine de caracteres « Edit » dans la langue active de l’interface. 


Modules MAGIQUES Des modules qui aident 
a developper des modules 

II existe un module appele Coder qui permet de 
tester la validite de votre code et vous donne ainsi 
une meilleur assurance pour construire des 
modules compatibles avec les regies de develop- 
pement de Drupal. 

► http://drupal.org/project/coder 

II existe aussi un module appele Schema qui vous 
apportera une grande aide pour developper des 
modules qui discutent avec la base de donnees. 

► http://drupal.org/project/schema 

Enfin, il est difficile de fonctionner sans I'indispen- 
sable module Devel que nous avons deja croise 
plusieurs fois. Ce dernier dispose notamment d'un 
bloc specialement congu pour les developpeurs 
permettant de simplifier toutes sortes d'operations 
courantes. 

► http://drupal.org/project/devel 


Activation du module 

Notre premier module est maintenant complet, il ne reste plus qu a 
l’activer pour en observer le resultat. 

Bienvenue 

Sdi/mrs par Marine le mar. Q&Q2/2Q09 - 23:38 Recrutement 

Bienvenue sur le site de Colchique Conseil. 
le cabinet de conseil en ressources humaine qui a Vethique a coeur. 

2 commentates Ensavoirplus 2 fichiers attaches Modifier 


Figure 14-4 

Notre module en action, 
notez le nouveau lien modifier 


Comme vous le voyez, le lien a effectivement ete ajoute a chacun des 
conte nus, vous venez done de realiser avec succes votre premier module. 


En resume 

• Pour qui possede quelques connaissances sur PHP, la creation de 
modules est beaucoup trop simple pour s’en priver. 

• Les modules permettent d’agir au coeur de Drupal et de Fadapter 
precisement a vos besoins. 

• Si vous avez besoin d’aide, n hesitez pas a poser une question sur le 
forum drupalfr.org, dans la section Developpement. 
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Mettre son site en production 


C’est le grand moment. Votre site est enfin pret et toutes les 
fonctionnalites sont correctement implementees. La tentation 
de le mettre en ligne est grande, mais encore un peu de 
patience. Voyons d’abord ensemble toutes les etapes a ne pas 
negliger pour effectuer une mise en production parfaite. 


SOMMAIRE 

► Mettre a jour son installation 
Drupal 

► Deployer son site sur le serveur 
de production 

► Faire des reglages pour obtenir 
de meilleures performances 

► Creer une installation multisite 
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Pourquoi parler de cela maintenant ? 

Drupal est un ecosysteme bien vivant qui a sans aucun doute encore 
evolue pendant que nous travaillions d’arrache-pied pour construire 
notre site. II y a fort a parier que dans rintervalle de temps, certains 
modules, et Drupal lui-meme, ont change de version, corrigeant ainsi 
anomalies et failles de securite. 

C’est done le moment ideal, maintenant que nous maitrisons Drupal et 
notre site dans les moindres details, de proceder a une rapide mise a jour 
nous assurant que notre mise en production sera la plus parfaite possible. 

Doit-on toujours tout mettre a jour ? 

Decider de ce que vous devez ou non mettre a jour doit etre fait en fonc- 
tion de ce que la nouvelle version de chaque element contient concrete- 
ment. 

Soit il s’agit d une mise a jour concernant des anomalies corrigees ou des 
problemes de securite et dans ce cas, il y a toujours urgence. S’agissant de 
failles de securite, le seul fait qu’un correctif soit publie implique que 
votre site est potentiellement en danger. En effet, cette situation signifie 
que des faiblesses ont ete detectees, et que toute personne malinten- 
tionnee desireuse d’attaquer votre site en utilisant ces failles dispose 
d’emblee de toutes les informations necessaires sur le Web pour mener 
son oeuvre a bien. 

D’une maniere generale, les mises a jour de securite du coeur de Drupal 
sont en permanence visibles sur la page d’accueil de drupal.org. Nous vous 
recommandons vivement de vous abonner aux flux RSS vous prevenant 
en temps reel des nouvelles mises a jour pour Drupal, et pour tous les 
modules contribution. Pour cela, ajoutez a votre client RSS le flux offi- 
ciel des annonces de securite de drupal.org, http://drupal.org/security/rss.xml. 

S’il s’agit dune mise a jour dite « majeure », e’est-a-dire impliquant un 
changement du premier chiffre du numero de version (par exemple, de 
Drupal 6.12 vers Drupal 7.0), la mise a jour ne doit jamais etre effectuee 
a la legere, que ce soit pour Drupal ou l’un des modules contribution. Il 
faut en effet etre certain que la nouvelle version fonctionne correctement 
avec votre site, ce qui demande generalement du temps. 

Enfin, evitez de mettre a jour un module stable en utilisant une version 
plus recente mais encore a l’etat de developpement ou en beta. Ces ver- 
sions sont de maniere generale deconseillees pour un site en production. 
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Le tableau de bord des mises a jour 

Un autre moyen pour se tenir au courant des mises a jour consiste a 
exploiter le module Update status que nous avons active au debut de notre 
projet. Ce module a pour role, souvenez-vous, d’aller regulierement sur le 
site drupal.org afin de verifier que les versions de Drupal et de tous les 
modules actives sont a jour. En cas de decouverte d une mise a jour impor- 
tante (typiquement la correction d une faille de securite), il vous previent 
sur chaque page de Y administration avec le message suivant : 


■ Une mise a jour cle securite est disponible pouruotre version de Drupal. Afin de garantir la securite de votre Figure 15—1 

serveur, effectuez immediatement la mise a jour ! Voir la page des mises a jour disponibles pour plus 
d'informations. 

mises a jour sont disponibles. 


Drupal nous avertit que de nouvelles 


Si vous cliquez sur le lien Mises a jour disponibles , vous etes alors redirige 
sur une liste de versions pour fensemble des modules actives. Vous 
pouvez aussi a tout moment afficher cette page en allant dans Adminis - 
trer > Rapports puis Mises a jour disponibles. 


Bonne Pratique Etre tenu au courant des mises a jour 

Si vous cliquez sur I'onglet Parametres, vous avez la possibility d'indiquer une ou plusieurs 
adresses de courriel pour etre prevenu automatiquement des lors qu'un module, ou Drupal lui- 
meme, a besoin d'une mise a jour. En effet, le module Update status ne se contente pas d'affi- 
cher simplement la page des mises a jour disponibles, mais verifiera regulierement par I'inter- 
mediaire du cron leur mise a disposition. 

Les differents reglages de la page vous permettent de determiner a partir de quel niveau de 
criticite vous desirez etre notifie. 


En tete de la liste se trouvent les informations sur le coeur de Drupal, 
suivies par les informations sur chacun des modules actifs. 


Drupal 6.9 


Mise a Jour de securite requlse ! 0 

Version recommandee : 

6.12 (2009-mai-1 3) 

Telechargement 

Notes de version 

Mise a jour de securite : 

6.1 2 (2009-mai-1 3) 

Telechargement 

Notes de version 

Mise a jour de securite : 

6.11 (2009-avr.-30) 

Telechargement 

Notes de version 

Mise a jour de securite ; 

6.10 f2009-fevr.-25) 

Telechargement 

Notes de version 

Contient : Block. Book , Color. Comment. Contact , Content translation. Fitter Help. Locale , Menu. Node. 

QpeniD , PHP titter Path. Ping , Poll, Profile , Search, Systog. System. Taxonomy. Throttle, Tracker Update 

status. Upload, User . ; amumerat, amumeraf-mobile 




Figure 15-2 Detail des informations sur la mise a jour critique de Drupal 


Ici, les informations sur le coeur de Drupal sont pour le moins expli- 
cites... Cette version nest plus du tout a jour et contient des failles de 
securite a combler. 
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D’une maniere generale, chaque ligne dispose d’un code couleur vous 
permettant d un coup d’oeil de savoir ou vous en etes. Lorsqu’ une mise a 
jour critique a appliquer rapidement est disponible, le fond est rouge 
comme nous venons de le voir. 


Figure 15-3 

Detail des informations sur la mise a jour 
importante du module CCK 


Content Construction Kit (CCK) 6.X-2.2 M ise a jour disponible O 

Version recommandee : 6.X-2.3 (2009-juin-05) Telechargement | Notes de version 

Contient : Content Content Copy, Fieidgroup, Node Reference, number, Option Widgets , Text, User Reference 


Lorsqu il s’agit d une mise a jour critique touchant a la securite du sys- 
teme, vous etes en plus averti par un message supplemental : Mise a 
jour de securite requise ! 


Figure 15-4 

Detail des informations 
sur la mise a jour critique 
du module Views 


Views 6.X-2.5 


Mise a jour de securite requise ! O 

Mise a jour de securite : 

6.X-2.6 (2009-juin-lQ) 

Telechargement 

Notes de version 

Egalement disponible : 

6.x- 3.x- dev (2009-juin-26) 

Telechargement 

Notes de version 

Contient : Views, Views Ut 





Lorsqu il s’agit dune mise a jour peu critique voire non critique, le fond 
jaune est utilise. 


Figure 1 5-5 voting api e.x-2.o-rc2 

Detail des informations sur Version recommandie . Bx . 2 0 (200 g. iuin . 24) 

une mise a jour non critique, Contlent . VolmgAPI 
ici pour le module Voting API 


Mise a jour disponible A 
Telechargement Notes de version 


Si le module Update status ne peut trouver d ’informations de version, ce 
qui est typiquement le cas pour le module que nous avons cree nous- 
meme, le fond est gris. 


Figure 15-6 

Exemple d'information 
pour un module non connu 
par drupal.org 


mon_module 6.X-1.0 

Contient : Mon Module 


Aucune version disponible 


A 


Enfin, si aucune mise a jour n’est disponible, le fond est simplement 
vert. 


Figure 15-7 

Tout est au vert, aucune mise a jour 
n'est a programmer. 


Comment RSS G.x-2.0 

Contient : Comment RSS 


A jour 




360 


www.frenchpdf.com 




tj 

3 

T3 

© 

En cliquant sur le lien Notes de revision , par exemple pour le module 
Views concerne par une mise a jour critique, nous obtenons plus d’infor- 
mations sur ce qui a ete corrige. 


views 6.X-2.6 

] View | | Revisions j 

merlinofchaos -June 10, 2009 - 22:09 6.x Security update Bugfixes New features 

Official release from CVS tag: DRUPAL-6--2-6 

First released: June 10. 2009 - 22:09 
Download: views-6.x-2.6.tar.gz 
Size: 1.4S MB 

md5_file hash: a39S27a5430373abS50Sf2773b0bcSea 
Last updated: June 10. 2009 - 22:11 

View usage statistics for this release 

Bugs fixed 

* #419226 by kelvincool: Respect admin theme during views ajax operations. 

* #419270 by voxpelli: set_where_group() could fail if no previous groups. 

« #422054 by yhahn: Protect exports from improperly indenting multiline strings. 

* #437070 by milceryan: Base table formerly limited to 32 characters. 

* #317271 by quicksketch: ensure_my_table[) limited to one relationship per table. 

* #441520 by jonathanl055: Allow the "time ago" date format to work on future dates as well. 

Figure 15-8 La liste des corrections effectives par la mise a jour critique du module Views 

Mise a jour du code source 

Mise a jour de Drupal 

Pour rester simple dans notre expose, nous partirons du principe, pour 
toutes les mises a jour qui vont suivre, que vous n’avez jamais modifie le 
moindre fichier fourni en standard ni meme ajoute quoi que ce soit dans 
les dossiers, que ce soit pour un module ou pour Drupal lui-meme. II 
s’agira done purement et simplement de supprimer les anciennes ver- 
sions pour decompresser a la place les nouvelles. 

Pour mettre a jour le coeur de Drupal, nous commencerons par tele- 
charger la nouvelle archive en utilisant le lien Telechargement qui se 
trouve sur la premiere ligne des versions de retard qui nous sont indi- 
quees sur la page des versions disponibles. 

Dans notre cas, il s’agit de Drupal 6.12. Notez qu’il nest pas necessaire 
d’appliquer toutes les versions de retard. Pour Drupal comme pour les 
modules, e’est la derniere version qui importe. 

L’objectif est maintenant de remplacer les sources obsoletes par la nou- 
velle version. La seule precaution que nous devons prendre concerne le 
dossier sites qui contient tout ce que nous avons modifie : le parame- 
trage, les modules ainsi que les themes que nous avons installes ou crees. 

www.frenchpdf.com 


15 - Mettre son site en 


Drupal 6 - Concevoir et deployer ses applications 


Bon A SAVOIR Technique avancee et ultrarapide pour mettre a jour Drupal 


£ 


Pour les utilisateurs avarices et rompus a la ligne de commande, pour 
mettre a jour, de la maniere la plus sure possible, une installation Drupal 
qui a ete lourdement modifiee, le moyen efficace consiste a utiliser les 
commandes di ff et patch. Pour cela, il faut telecharger sur drupal.org les 
deux archives correspondent I'une, a la version de votre installation et 
I'autre, a la version cible. Vous decompresserez ensuite ces deux archives 
dans un meme dossier et utiliserez la commande diff pour creer un 
patch de mise a jour 

diff -Naur drupal-6.9 drupal-6.12 > drupal-6. 9-6. 12. patch 
Ensuite, il ne vous reste qu'a appliquer le patch a la racine de votre 
Drupal, d'abord en mode simulation : 

patch -pi --dry-run < . ./patchs/drupal -6. 9-6. 12 . patch 
Si vous constatez des erreurs, il s f agit surement d'un fichier que vous 
avez modifie, et vous aviez surement une tres bonne raison pour faire 
une chose pareille. 

Comparez le fichier problematique avec sa version d'origine dans le dos- 
sier drupal-6.9 avec un outil comme WinMerge (Windows) ou Meld 
(Gnome). Corrigez ce qui pose probleme ou, le cas echeant, sauvegardez 
votre modification a part pour la reappliquer plus tard. 

Lorsque le patch passe enfin correctement, vous pouvez relancer la com- 
mande, cette fois en mode definitif. 

patch -pi < . ./patchs/drupal-6. 9-6. 12. patch 
Cette approche permet de tenir son Drupal a jour malgre un coeur 
modifie. C f est aussi une bonne occasion de vous demander a chaque fois 
si telle ou telle modification qui bloque la mise a jour pourrait ou non 
etre remplacee par un module a part entiere. 


Pour cela, nous decompressons la nouvelle archive au meme niveau que 
le dossier de notre Drupal, obtenant ainsi un dossier drupal - 6.12. 
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Figure 15-9 

Decompression de la nouvelle 
archive sous Gnome 


drupal 


drupal-6. 12. tar. g. 


# Ouvrir avec * Gestionnaire d'archives > 
Ouvrir avec une autre application... 

*= Couper 
ijf Copier 
Creer un Hen 
Renommer... 

¥’ Mettre a la corbellle 
Extraire ici 


Seul le dossier si tes est a sauvegarder lors d une mise a jour, aussi le depla- 
cerons-nous du dossier drupal au dossier drupal -6 . 12. Ensuite, il ne reste 
qua deplacer le dossier drupal dans un lieu sur a des fins d’archivage, et a 
renommer le dossier drupal-6. 12 en drupal. La mise a jour est terminee. 
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Mise a jour d’un module 

La mise a jour d’un module est beaucoup plus simple que celle de Drupal : 
la suppression de l’ancien dossier du module, puis la decompression du 
nouveau a sa place sont les deux seules actions a effectuer. 

Mise a jour d’un theme 

La mise a jour d’un theme se passe strictement de la meme maniere que 
celle d’un module. 


Mise a jour de la base de donnees 

Sauvegarde de la base de donnees 

La majeure partie de la configuration de Drupal se trouve dans la base de 
donnees. Lorsqu’un module, ou Drupal, change de version, il faut done 
mettre a jour cette base pour qu’elle s’accorde avec ces nouveautes. 

En premier lieu et avant toute action, nous devons faire une sauvegarde 
de cette base de donnees pour nous premunir de tout incident pouvant 
survenir lors de la mise a jour. Si un probleme inattendu apparaissait au 
cours de l’operation, vous conserverez ainsi la possibility de revenir en 
arriere et de restaurer la version de depart de la base de donnees. 

Pour sauvegarder votre base, nous allons utiliser phpMyAdmin pour 
effectuer son « vidage » (en anglais dump). Ce vidage se presentera sous 
la forme d’un fichier SQL qui contiendra l’ensemble des donnees de la 
base et que l’on pourra utiliser en cas de probleme. 

Pour ce faire, allez sur l’URL de phpMyAdmin (http://localhost/phpmyadmin) 
et selectionnez la base de donnees drupal que nous avons creee en debut 
d’ouvrage. Cliquez ensuite sur l’onglet Exporter. 

Dans la zone Exporter , cliquez sur le lien Tout selectionner de maniere a ce 
que toutes les tables soient prises dans le vidage. 


- Exporter 

T out selectionner f T out 
des elect! on ner 


access 



access log 


- 

actions 



actions_aid 



actbns_old_contrib 

actbns_registry 


1 V 


Figure 15-10 

Selection de toutes les tables pour le vidage 
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Figure 15-11 

Definition du mode de transmission 


Bon a SAVOIR Faites vos sauvegardes 
en ligne de commande 

Pour creer des vidages de maniere rapide et effi- 
cace, il n'y a rien de plus efficace que la ligne de 
commande. 

Pour creer un vidage pour une base mySQL, la syn- 
taxe est : 

mysqldump drupal -p qui apparaits/ 
sauvegardes/drupal_1.0. sql 
Et pour une base postgreSQL : 
pg_dump -U postgres drupal > / 
chemi n/vers/sauvegardes/ 
drupal_1.0. sql 


Bon a SAVOIR Pouvoir mettre a jour meme si 
vous n'etes pas administrateur 

Si vous avez besoin d'effectuer une mise a jour 
mais que vous n'etes pas connecte en tant 
qu'administrateur, il est possible de changer dans 
le fichier setti ngs . php la variable suivante : 

$update_free_access = TRUE; 

Prenez cependant grand soin de remettre cette 
valeur a FALSE des que votre mise a jour est ter- 
minee car, dans le cas contraire, n'importe qui 
pourrait mettre a jour votre site. 

Figure 15-12 

La page de mise a jour de Drupal 


364 


Juste en dessous, verifiez que le bouton radio SQL est bien selectionne 
pour produire un vidage en langage SQL. En bas de la page, dans la 
zone Transmettre , activez la case a cocher a gauche du libelle, puis sai- 
sissez le nom du fichier final et cochez la compression aucune. 

r- gi Transmettre 

Models de nom de fichier 1 : drupal_i.o[sql I 

Compression: # aucune "zippe" "gzippe" 


Ceci fait, cliquez sur le bouton Executer ; une boite d enregistrement doit 
alors apparaitre pour vous permettre de sauvegarder le vidage sur votre 
disque local. Placez ce fichier dans un dossier a part, dedie aux sauvegardes. 

Le script update.php 

Vous pouvez a present proceder a la mise a jour de la base de donnees 
Drupal, et pour cela, il vous faut faire appel a une page speciale : 
update . php. Assurez-vous au prealable que vous vous etes bien connecte 
en tant quadministrateur, puis saisissez fadresse http://www.colchique- 
conseil.fr/update.php pour afficher la page de mise a jour. 

Drupal database update 

Use this utility to update your database whenever a new release of Drupal or a module is 
installed. 

For more detailed information, see the Installation and upgrading handbook. If you are unsure 
what these terms mean you should probably contact your hosting provider. 

1 . Back up your database. This process will change your database values and in case of 
emergency you may need to revert to a backup. 

2, Back up your code. Hint: when backing up module code, do not leave that backup in the 
'modules' or 'sites/Vmodules' directories as this may confuse Drupal's auto-discovery 
mechanism. 

3, Put your site into maintenance mode. 

4. Install your new files in the appropriate location, as described in the handbook. 

When you have performed the steps above, you may proceed. 

| Continue | 


Drupal vous indique ici qu il est sage de faire au prealable une copie de 
sauvegarde de votre base de donnees et du code du site, ce que nous 
avons deja fait. Vous pouvez done appuyer sur le bouton Continue. 

Sur la page suivante, en deroulant la section Select version, vous obtenez 
la liste des modules actives suivi du dernier numero de version que 
Drupal a detecte pour chacun d’entre eux. 
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content module : Figure 15— 13 

- Derniers numeros de version des modules 


Attention, ces numeros de version ne correspondent en rien aux 
numeros de version des modules eux-memes, meme si generalement 
leurs auteurs suivent la logique qui veut que 6202 signifie « mise a jour 
n° 2 de la version 6.2 du module ». 


Si vous deroulez la liste, vous pouvez voir que cette version est eventuel- 
lement suivie dune serie d’autres versions allant jusqu’a l’entree No 
updates available. Pour illustrer cette liste qui nest pas tres claire, pre- 
nons un exemple. 

Si, pour un module, nous avons les versions 6202, 6203 et 6204, cela 
signifie que lorsque Drupal fera sa mise a jour, il commencera par appli- 
quer la mise a jour n° 6203 (la 6202 etant la version courante) puis pour- 
suivra sur la 6204, avant de passer au module suivant. Si vous souhaitez 
ne mettre a jour qu’un seul module, vous pouvez le faire en selectionnant 
manuellement No Update Avalaible pour tous les autres modules. 


Bon A savoir 

Le fonctionnement des mises a jour 

Pour ceux qui craindraient que la mise a jour soit 
trop longue et depasse le temps alloue a PHP pour 
I'execution d'un script, sachez que cette procedure 
ne se fait pas en une seule passe. En realite, la 
barre de progression est rafraichie par des appels 
successifs a la procedure de mise a jour, chaque 
appel etant calibre pour ne jamais depasser 
30 secondes. 


Lorsque vous etre pret, appuyez sur le bouton Update. Une barre de pro- 
gression apparait pour indiquer favancement des mises a jour, module 
par module. Le processus s’acheve par une page indiquant les operations 
realisees et les eventuelles erreurs. 


Drupal database update 

U pdates were attempted. If you see no failures below, you may pioceed happily to the 
administration pages. Otherwise, you may need to update your database manually. All errors 
have been logged. 

O Main page 
° Administration pages 

The following queries were executed 
system module 
Update #6050 

a No queri es 

content module 
Update #6010 

' No queries 


Modules magiques Drupal entierement 
en ligne de commande 

Les amoureux de la ligne de commande en 
revaient, le module Drush I'a fait. Avec cet outil, 
vous pouvez controler entierement Drupal dans 
une console. Quelques exemples ? 

Activer un module : 

./drush enabled mon_module 
Mettre a jour la base de donnees : 

./drush updatedb 
Obtenir I'etat de tous les modules : 

./drush statusmodules 
Vider les caches : 

./drush cache clear 
Fantastique, non : 

► http://drupal.org/projetc/drush 


Figure 15-14 

Les mises a jour se sont correctement effectuees. 


Notre base de donnees est a present totalement a jour et nous pouvons com- 
mencer a tester pour verifier qu aucune regression n est apparue sur notre site. 
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La procedure de mise a jour de la base de donnees est un moment assez 
critique dans la vie de votre site. Normalement, pour les modules les plus 
utilises, cette etape se passe tres bien. 

Toutefois, si des erreurs graves apparaissent a la fin de la procedure de 
mise a jour, lisez chacune d’elles avec soin et verifiez leur cause dans la 
base de donnees. Si vous ne comprenez pas ce qui a pu se passer, stoppez 
tout et allez poser la question sur le forum de drupalfr.org, dans la section 
Support general. Prenez soin de donner la version du Drupal que vous 
utilisez, et de recopier les erreurs qu’il vous a renvoyees. 

Une fois la cause identifiee et corrigee, vous devez relancer la procedure 
de mise a jour, et done restaurer prealablement la sauvegarde des don- 
nees que vous avez effectuee. 

Pour cela, utilisez phpMyAdmin et cliquez cette fois sur l’onglet Sup - 
primer. Un message divertissement apparait afin de confirmer loperation. 


An nonce de la page http://www.colc hiqu e-con seil.fr : O 


Figure 15-15 

Confirmation de la suppression 
de la base de donnees Drupal 


Confirmez votre choix. Une fois la base detruite, nous allons la recreer 
de la meme maniere que lors de finstallation. 

MySQL localhost 

^ Creer une base de donnees © 

Figure 15—16 dmpaj I Intenclassement 0 | | Greer 

Recreation de la base de donnees Drupal M Intenclassement pour la connexion MySQL; Intercbssemant cTl © 


Vous etes sur le point de DETR U I R E une base de donnees ! 
Voulez-vous vraiment effectuer : 

DROP DATABASE ’drupal' 


©Annuler ^OK 


Notre base etant creee, nous allons maintenant restaurer ses donnees 
grace a notre sauvegarde en cliquant sur fonglet Importer. 


Figure 15-17 

Restauration de la sauvegarde 


-Fichier a importer 

Emplacement du fichier texte oran/d^wri loada'd rupal_i ,c| ( Parcourir... | (Taille maximum: 8 192 Kio) 
Jeu de caracteres du fichier: | utfs 0 ) 

Ces modes de compression seront detectes automatiquement : aucune, gzip, zip 


Dans la zone Fichier a importer , cliquez sur Parcourir de maniere a selec- 
tionner le fichier drupal_1.0. sql que nous avons cree auparavant. Ceci 
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fait, cliquez sur Executer. Lorsque rimportation est terminee, php- 
MyAdmin vous indique que tout s’est bien passe : 


<zf L'i import at ion s'est terminee avec succes, 92 requetes executees. 


Figure 15-18 

Le message de bonne fin de I'importation de phpMyAdmin 


Vous pouvez maintenant relancer votre procedure de mise a jour. 


Avez vous bien teste ? 

Votre installation Drupal est maintenant a jour est vous etes de plus en 
plus tente de mettre votre oeuvre en production. Mais il est important de 
verifier auparavant que tout fonctionne parfaitement. Voyons ci-apres les 
points a passer en revue pour avoir Tesprit tranquille. 

Les tests fonctionnels 

Avez-vous teste toutes les fonctions de votre site ? Pour cela, le mieux est 
de se construire une liste a partir de votre definition des besoins. A chaque 
fonctionnalite correspond une case avec une coche indiquant si le test s'est 
passe sans probleme. Ce type de document est appele cahier de recette. 


Bon A SAVOIR Restauration rapide de la base 
de donnees en ligne de commande 

Comme pour la creation de la sauvegarde, il est 
possible en ligne de commande de restaurer une 
base de maniere tres rapide. 

Pour MySQL d'abord : 
mysql -p 

mysql> drop database drupal 
mysql> create database drulal 
mysql > <CTRL-C> 

cat /chemin/vers/ma/sauvegarde/ 

drupal_1.0. sql | mysql -p 
Puis pour PostgreSQL : 
dropdb -U postgres drupal 
createdb -U postgres drupal 
cat /chemin/vers/ma/sauvegarde/ 

drupalJL.O. sql | psql -U postgres 


Fonctionnalite 

Utilisateur 

ResuHat 

Valide ? 

Ajouter de nouveaux articles 

Ma rine 

Article ajoute mats non visble en page d'accueil 

QUI 

Corriger un article 

Philppe 

Artie le corrge et a l&fcat ■■ corrige :■ 

NON 






Figure 15-19 

Exemple d'un cahier de recette simplifie 


Les tests techniques 

Le premier point technique a verifier est la compatibilite de votre site avec 
l’ensemble des navigateurs cibles. Lors de la definition de notre projet, 
nous avons identifie un besoin de compatibilite avec Mozilla Firefox 3.x et 
Microsoft Internet Explorer 3.x. Il est done important de verifier que tout 
fonctionne correctement sur ces deux plates-formes. Ne vous contentez 
pas de tester avec un seul systeme d exploitation. Si votre site passe parfai- 
tement sous Mozilla Firefox 3.5 pour Linux, rien ne dit que ce sera le cas 
avec le meme navigateur sur Mac OS ou Microsoft Windows. 

De meme, pensez a la resolution d’ecran qui a ete definie comme 
minimum (ici 1280 x 1024). Bien souvent, les developpeurs travaillent 
sur des ecrans immenses et oublient de verifier que leurs realisations 
s’affichent correctement sur des ecrans de moindre resolution. 
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Si vous pouvez disposer dun serveur de test qui reproduirait a l’iden- 
tique (systeme d’exploitation, configuration materielle) le serveur de 
production, effectuez vos tests techniques sur cette machine. 

Validez ! 

Le consortium W3C definit les normes qui regissent flnternet. 
XHTML ou CSS font partie de ces normes et il convient d’etre certain 
que votre production est parfaitement compatible. 

Pour valider le code XHTML de votre site, vous avez la possibility duti- 
liser foutil en ligne fourni par le W3C (http://validator.w3.org/). 

Si votre site est accessible sur flnternet, saisissez son adresse dans le pre- 
mier onglet du validateur. 


mt 


Markup Validation Service 

Check the markup (HTML, XHTML., ...) of Web documents 



Validate by URI Validate by File Upload Validate by Direct Input 

Figure 15-20 

Validation d'une URL 

Validate by URI 

Validate a document online: 

sur le validateur XHTML du W3C 

Address: http : //www . colchique-conseil. f r| 


Dans le cas contraire, utilisez le dernier onglet et copiez-y le code source 
a valider. 


Bon A SAVOIR Microsoft Internet Explorer est-il vraiment si mauvais ? 

Microsoft Internet Explorer est repute pour sa tres mauvaise prise en charge des normes CSS. C'est 
en partie faux. En realite, ce sont les anciennes versions de ce navigateur qui souffraient de ce 
defaut ; les nouvelles - et particulierement les versions 7 et 8 - sont quant a elles bien meilleures. 
De nombreuses entreprises ayant utilise Microsoft Internet Explorer comme outil principal de 
navigation sur leur intranet, Microsoft ne peut done pas casser cette compatibilite avec ses 
defauts de jeunesse pour d'evidentes raisons commerciales. 

II est cependant possible de creer un site parfaitement compatible avec le W3C et Microsoft 
Internet Explorer dans sa version 8, en inserant dans I'en-tete de vos pages la balise suivante : 

<meta http-equiv= M X-UA-Compatible" content="IE=8 M /> 

De cette maniere, Microsoft Internet Explorer 8 basculera automatiquement en mode 
« compatible », vous evitant ainsi de developper une feuille de style specifique pour ce navigateur. 
Dans le cas bien sur ou votre besoin de compatibilite n'englobe pas les versions precedentes. 
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Vous pouvez valider vos feuilles de style en utilisant un autre outil du 
W3C disponible a l’adresse http://jigsaw.w3.org/css-validator/ et qui fonctionne 
exactement de la meme maniere. 

Enfin, vous avez aussi la possibility de valider vos flux RSS en allant a 
l’adresse http://validator.w3.org/feed/. 

De I’integration a la production 

Choisir son hebergement 

Nous avons travaille jusqu’a present en local sur une machine de deve- 
loppement. Pour que notre site soit rendu public, il est necessaire de 
transferer son code et sa base de donnees sur une machine visible depuis 
Tlnternet. C’est ce que Ton appelle communement un hebergement. 

Pour de gros sites, cet hebergement est un service payant effectue par des 
hebergeurs. II convient de choisir une telle societe en etudiant avec soin 
les points suivants. 

• Le type d’hebergement : il peut s’agir d une machine dediee, mutua- 
lisee ou virtuelle. La machine dediee est une machine physique qui 
ne travaille que pour vous. La machine mutualisee est aussi une 
machine physique, mais qui heberge d’autres sites en plus du votre. 

Enfin, la machine virtuelle peut etre vue comme une ou plusieurs 
« tranches » de machine physique, une tranche vous etant totalement 
dediee. Le choix d une formule depend principalement du trafic pre- 
visionnel que vous avez estime, et bien evidemment de votre budget. 

• Le debit montant et descendant de faeces a Tlnternet : plus le trafic 
attendu est important, plus ce debit doit etre eleve. 

• La capacite de stockage du serveur : cet aspect est important si vous 
comptez heberger des contenus lourds (par exemple, des videos). 

• Les applications disponibles : dans un environnement mutualise, ou 
sur demande pour un dedie ou un virtuel, vous devez disposer de tout 
Tenvironnement logiciel pour faire tourner votre site Drupal : 

Apache, PHP, MySQL/PostgreSQL, phpMyAdmin et un panel, qui 
est un outil simplifie d’administration du serveur. 

• Le contrat de service : aussi appele SLA ( Service Level Agreement), il 
precise le delai maximal d’attente avant intervention lors dune 
panne, et le delai maximal d’attente avant remise en service d’un ser- 
veur. Plus ces temps sont courts, plus le service est cher. Ce contrat 
de service est done a moduler en fonction de vos besoins. Notez qu’il 
peut aussi inclure la prise en charge de prestations liees aux logiciels 
installes sur les serveurs (parametrage, mise a jour, etc.). 
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Bon a savoir 

Un hebergement libre pour le libre 

Un hebergement sans publicity de qualite et gra- 
tuit, c'est possible grace au libre. 

L'association a but non lucratif TuxFamily met en 
effet a la disposition de tout projet en rapport avec 
la philosophie du libre un hebergement gratuit, de 
niveau professionnel et de type « mutualise ». Cet 
hebergement comprend tout ce qui est necessaire 
a la mise en production d'un site sous Drupal, y 
compris une base de donnees PostgreSQL (base de 
donnees concurrente de MySQL, mais plus rare a 
trouver chez un hebergeur). 

Notez cependant que meme si ce service est gra- 
tuit, il repose sur I'entraide et le partage. Aussi, 
toute donation de votre part en temps (pour admi- 
nister les serveurs ou aider les autres utilisateurs) 
et en argent (a la mesure de vos moyens), per- 
mettra a ce projet de continuer a democratiser 
I'acces a I'lnternet. 

► http://www.tuxfamily.org 


Si votre projet est un site personnel, vous pouvez aussi vous tourner vers 
des hebergements gratuits. La majorite des fournisseurs d’acces a 
Tlnternet (FAI) mettent a la disposition de leurs abonnes des espaces 
personnels compatibles avec Drupal. Eux aussi disposent d une interface 
d’administration simplifiee (panel). 

Acheter son nom de domaine 

Pour disposer d un site visible sur I'lnternet, vous devez disposer d un 
nom de domaine. Dans notre cas, il s’agira de colchique-conseil.fr. 

Un nom de domaine ne s’achete pas, il se loue pour une periode de 
temps donnee. La societe vers laquelle vous vous tournerez pour effec- 
tuer cette location est un bureau d’enregistrement des noms de domaine. 
Il existe plusieurs societes de ce genre, qu’ il convient d’etudier pour 
determiner le meilleur rapport service/prix. 

Une fois la periode de location ecoulee, le bureau d’enregistrement qui 
vous a loue ce nom vous demandera si vous souhaitez renouveler cette 
location. Si vous n’y pensez pas (ou que la societe ne vous previent pas), 
quelqu’un d’autre pourra alors acheter ce nom de domaine a votre place. 
Soyez done vigilant et pensez a planifier vos renouvellements. 


Attention Restez maitre de votre nom de domaine 

Ne laissez jamais une societe tierce acheter un nom de domaine a votre place. Il faut imperati- 
vement que ce nom de domaine soit a votre nom ou a celui de votre societe. 

Par le passe, il y a deja eu des cas ou certaines societes peu scrupuleuses induaient dans leur 
offre de realisation d'un site I'achat du domaine et le service d'hebergement. Lorsqu'un de ces 
sites connut le succes, la societe refusa que I'hebergement passat chez un autre prestataire et 
prit le nom de domaine en otage car elle I'avait achete a son nom. 

De maniere generale, diversifiez vos fournisseurs en en prenant un pour le nom de domaine, 
un autre pour I'hebergement et un eventuel troisieme pour la realisation. 


Une fois le nom de domaine achete, le bureau d’enregistrement a pour 
tache de prevenir la planete de son existence. C’est le role des serveurs 
DNS {Domain Name Server). Les serveurs DNS a travers le monde dis- 
cutent en permanence entre eux pour s’echanger les noms de domaine 
crees ou modifies. 

Mais le role principal d’un serveur DNS est de permettre a l’internaute, 
lorsqu’il saisira l’adresse www.colchique-conseil.fr dans son navigateur, 
d’aboutir sur le serveur de votre hebergeur. Il convient done de parametrer 
votre nom de domaine achete avec l’adresse IP du serveur de votre heber- 
geur. Tous les bureaux d’enregistrement de noms de domaine disposent a 
cet effet d’une interface specifique permettant de creer cette association. 
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Le premier deployment 

Le grand moment est enfin arrive : votre site est termine, votre Drupal 
est a jour et vous avez teste tout ce quil vous etait possible de tester. Vous 
allez enfin pouvoir deployer votre oeuvre sur votre serveur de production. 

Dans la plupart des cas, l’hebergeur que vous avez choisi vous propose - 
en plus des indispensables Apache, PHP et MySQL (ou PostgreSQL) - 
une interface d’administration simplifiee vous permettant de deployer 
votre site sans posseder de connaissances particulieres (c’est le panel 
evoque precedemment). 

II existe de nombreux panels et il y a de fortes chances que votre heber- URL AlternC 

geur ait developpe un exemplaire qui lui est totalement specifique. II est — . _ „ r : — 

° . rr r 1 # r , Tl ► http://www.alternc.org/ 

done impossible de donner une procedure applicable pour fensemble des 

panels existants. Nous en presenterons un ci-apres qui a favantage d'etre 

comme Drupal, un projet libre : AlternC. 

Nous avons deja parametre le nom de domaine pour quil pointe sur 
fadresse de notre hebergeur. II nous faut a present declarer ce meme nom 
de domaine en tant que service web, grace au panel de notre hebergeur. 


Hebergement de domaine 

Le domaine demande est interditsur ce serveur, contactez I'administrateur 

Nom de domaine : www. I colchique-conseil.fr 

p-ieberger ce nouveau domaine | 

□ 

Heberger le DNS sur le serveur 


Figure 15-21 

Declaration du nom de domaine chez I'hebergeur 


Dans la mesure oil le serveur DNS est gere par notre bureau des enregis- 
trements de noms de domaine, nous allons prendre soin de decocher 
Heberger le DNS sur le serveur. Ceci fait, cliquez sur Heberger ce nouveau 
domaine. 


Votre nouveau domaine colchique-conseil.fr a ete installe avec succes 
Cliquez ici pour continuer 

- Entrez le nom du domaine que vous souhaitez heberger. Le nom de domaine 
IMPORTANT : Si vous voulez un hebergement reel de domaine, il faut que les I 
hebergeur pour plus d'information. 

Plus d'info sur la gestion des domaines dans I' aide en ligne @ 


Figure 15-22 

Le domaine est maintenant cree. 


Copier les sources du site 

Le plus simple pour envoyer notre code source sur le serveur est d utiliser 
un compte FTP. 
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Creation (Tun compte ftp 


Figure 15-23 

Creation d'un compte FTP sur AlternC 


Figure 15-24 

Le compte FTP est maintenant cree. 


Figure 15-25 

Detail de I'arborescence creee par AlternC via 
Gnome Nautilus 


Creation d'un compte ftp 

Horn ri'utilisateur admin 
Mot de passe i ********** 

Confirmer le mot de passe i ■■■■■■■■■*! 

Repertoire 

| Creer le compte FTP, j 

Ici, nous utilisons l’identifiant admin pour notre compte et un mot de 
passe difficile a casser (long, contenant des lettres et des chiffres et pas 
de mots identifiables dans un dictionnaire). La creation effective du 
compte est realisee en appuyant sur le bouton Creer le compte FTP. 


Le compte FTP a etc cree avec succes 
Horn d'utilisateur Repertoire 

□ J admin / 

| Effacer les utilisateurs selectionnes | 

Creation d'un compte ftp 


Vous pouvez tester votre nouvel acces avec un outil comme CuteFTP 
(sous Microsoft Windows) ou directement avec Nautilus sous GNU/ 
Linux et autres Unix. 

^ V ftp en tant que admin sur demo.alternc.org 
^ 3 www 

fifcolchique-conseil.fr 


Vous constatez alors que le panel nous a automatiquement cree un dos- 
sier www/col chi que-consei 1 . f r. Ce sera la racine de notre site Drupal. 

Mais pour verifier que tout fonctionne, nous allons au prealable creer 
dans le dossier colchique-conseil.fr un nouveau fichier index. php 
dans lequel nous placerons le code suivant : 

Code PHP de test du serveur 

<?php phpinfoC) ?> 

Une fois le fichier sauvegarde dans le dossier FTP www/col chi que- 
consei 1 .fr, nous pouvons verifier que tout fonctionne correctement a 
faide d : un navigateur : 

Tout fonctionne correctement, ce qui nous permet de passer a la derniere 
etape : recopier le contenu de notre dossier drupal dans le dossier 
www/col chi que-consei 1 .fr. Auparavant, pensez a detruire le script de 
test i ndex. php. 
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Fichier Edition Affichage Ajler a Signets Outils Onglets Aide 


^ S© § 

H htt p ://www , c ole h iqu e-c on s ei I .f r/ 


PHP Version 5.2.6-l+lenny3 


System 

Linux demo 2.6.26-bpo.l-vserver-686-bigmem #1 SMP Fri Dec 19 
08:24:21 UTC 2008 i686 

Build Date 

Apr 26 2009 21:57:45 

Server API 

Apache 2.0 Handler 
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Figure 15-26 

Cet ecran nous indique 
que le serveur fonctionne 
et que PHP y est operationnel. 


Cette operation realisee (ce qui peut prendre un certain temps !), nous 
pouvons verifier que Drupal fonctionne en rafraichissant la page de 
notre navigateur : 


Drupal 


■ I 

Site off-line 

The site is currently not available due to technical problems. Please try again later. Thank you 
to r yo u r u nde rstand i ng . 

If you are the maintainer of the site, ple^e check your dative setting in the settings, php File and eraure that 
your hosting provider's server is running. For more he£, see the tancbocto, or contact your hosting provider. 

T he myatf error was : Access denied for user TootWiocaihQst' {using password: YES}. 


Figure 15-27 

Notre site est en ligne, mais encore « off-line » 
pour cause d'absence de base de donnees. 


Cela est de bonne augure, puisque effectivement notre site est hors-ligne 
en l’absence dune base de donnees. 

Mettre en place la base de donnees 

Cette etape est tres proche de ce que nous avons appris a faire un peu 
plus haut pour une sauvegarde/restauration de base de donnees. La pre- 
mier etape consiste done a effectuer une sauvegarde de nos donnees. 
Cependant, n oubliez pas que votre installation contient pour l’instant 
beaucoup de donnees de tests. Veillez a faire un grand menage avant de 
creer la sauvegarde ; il serait dommage que ces donnees apparaissent en 
ligne et vous oblige au dernier moment a proceder au nettoyage directe- 
ment sur le serveur de production. 
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Une fois la sauvegarde achevee, nous pouvons creer sur le serveur la base 
de donnees et, par la meme occasion, definir le mot de passe permettant 
d’y acceder. Vous savez deja le faire avec phpMyAdmin, mais cela neces- 
site que votre hebergeur vous ait donne les droits de creation sur 
mySQL. Voyons done comment la meme operation est realisable avec 
AlternC en allant dans la section MySQL, et en cliquant sur le lien Utilisa - 
teurs MySQL. 


Figure 15-28 

Creation de la base de donnees MySQL 


Votre base de donnees principals n'existe pas, entrez ici un mot de passe pour la creer 

Mom d'utilisateui admin 

Motde passe j j 

Serveur SQL 127.0.0.1 
Base de donnees admin 
| Creer ma base de donnees principals | 


Une fois que vous avez choisi un mot de passe solide, cliquez sur le 
bouton Creer ma base de donnees principale. Attention, le nom de la base 
de donnees nous est impose par AlternC, ici e’est admi n. 

Une fois la base creee, nous utiliserons notre phpMyAdmin local pour 
creer une sauvegarde de notre base de donnees. Dans la section Trans - 
mettre , cochez cette fois le bouton radio gzippe. Nous obtiendrons ainsi 
une sauvegarde prenant beaucoup moins de place, et done plus rapide a 
transferer sur le serveur de l’hebergeur. 

A faide de votre connexion FTP, transferez la sauvegarde a la racine. 
Attention, ne placez jamais vos sauvegardes dans le dossier www/ 
colchique-conseil . fr car elles seraient automatiquement telechargea- 
bles par des tiers, rendant ainsi visibles les informations confidentielles 
quelles peuvent contenir (comptes utilisateur, mots de passe, etc.). 

Une fois la sauvegarde telechargee a la racine, nous retournons sur le panel 
AlternC pour cliquer, toujours dans la section A/lySQL, sur le lien Bases de 
donnees. Apparait alors une liste contenant notre seule base de donnees 
admi n et deux liens : Sauvegarde et Restauration. Cliquons sur Restauration. 


Figure 15-29 

Restauration de nos donnees locales 
sur le mySQL distant 


Restaurer la sauvegarde SQL de la base admin 

Entrez le nom du flchier contenant ties donnees SQL a restaurer dans la base. drupal_l 0 sql qz 
| Restaurer ma base de donnees | 

Note : Si le nom du fichier se termine par .gz, il sera decompresse avant. 


Saisissez le nom du fichier de sauvegarde que nous venons de transferer 
par FTP et cliquez sur Restaurer la base de donnees. AlternC nous con- 
firme alors que les donnees ont ete correctement reintegrees. 
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Pour que Drupal puisse reconnaitre la base de donnees, il nous faut 
modifier son fichier de parametrage defaul ts/setti ngs . php. Comme 
precedemment avec le fichier index. php, votre outil FTP vous permet 
d’editer directement ce fichier. Nous allons changer la reference a la base 
de donnees correspondant au MySQL local pour indiquer a present celle 
correspondant au MySQL de l’hebergeur, en prenant soin de saisir ici 
fidentifiant (admi n) et le mot de passe definis plus haut. 

$db_url = ’mysql ://admi n : mot_de_passe@l ocal host/drupal ’ ; 


Une fois le fichier sauvegarde, rafraichissons la page de notre navigateur 
pour juger du resultat. 




Contactez-nouE 

SZ Colchique 



Car chaquebnn ti'toertoe est unique... 

ClwehQr dans ce sita : 


Les Publications Les Billets FAQ 


Bienvenue 

jouAft pair ktdiiii* If 3 juil/el 2DQS - 11 11*. v. 

Bienvenue sur le site C ole hique Cons eit. 

ie catunet ae conseit en ressouices numaines qui aremique autond du coeur, 

2 commentaires Cn aavoirplus 2 tiehiers attaches 

Recrutement d'un equipe Exploitation pour une grande 
banque Allemande 

Prestation Realised: 

La miss i an acansiste en la constitution en un temps record d'un equipe dediees a I'exp I citation du 
s/sterue Intel maUque dune grande Liauque alleiriuEide. 


cofcttfque est une soclGte de cons ell en management specialise dans les res sources numaines dans 
le dumaiuu des lechnuluyies de nrifurrriatiuri~, 


□ 



Rejoignez-riGLis.. 


I Jem dutnisateLi : 


Motde passe: * 


Cmirieulez-iTiLH ! | 

* Creerun* nouveau compte 

• Demanderun nouveau mot 
de passe 



Figure 15-30 

Notre site, en ligne, pour de vrai ! 


Vous pouvez faire le tour du proprietaire et verifier ainsi que tout est en 
place. Vous detenez maintenant les cles d un site public visible par tous. 

Les deployments suivants 

Le temps a passe, et vous avez certainement eu de nouvelles idees pour 
ameliorer et etoffer votre site. Comme nous avons pris la bonne habitude 
de ne jamais travailler sur le serveur de production, toutes ces modifica- 
tions ont ete faites sur votre machine de developpement. II vient un 
moment oil ces nouvelles fonctionnalites sont pretes a etre deployees sur 
le serveur de production pour devenir accessibles a votre public. 
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Modules magiques Deployer vos reglages 
en toute simplicity 

II existe un module tres prometteur appele Deploy 
dont I'objectif est de combler cette lacune de 
deployment automatise. II est pour I'instant a 
I'etat de projet experimental mais fonctionne deja 
tres bien avec une base de donnees mySQL. Grace 
a lui, il sera possible de deployer automatique- 
ment les mises a jour sur le serveur distant apres 
les avoir testees en local, sans avoir a refaire toute 
I'administration a la main. 

► http://drupal.org/project/deploy 


Figure 15-31 

Activation du mode 
« maintenance » de Drupal 


Pour ce qui est du code (modification sur le theme, nouveaux modules, 
etc.), la manipulation est tres simple : il suffit de recopier les modifica- 
tions par FTP. 

Pour la base de donnees, les choses se corsent un peu. Generalement, vos 
modifications s’accompagnent d un certain nombre d actions d’administra- 
tion, par exemple activer un module, parameter un type de contenu, etc. 
Tout ceci est, comme nous l’avons vu, stocke dans la base de donnees. Or, 
cette base de donnees dans l’environnement de developpement ne peut plus 
etre integree telle quelle sur le serveur de production, car vous ecraseriez 
toutes les informations qui ont ete ajoutees entre temps (nouveaux contenus, 
nouveaux commentaires, etc.) par vos utilisateurs et visiteurs. 

A Theure actuelle, il n existe malheureusement pas de solution fiable a ce 
probleme, qui est somme toute le seul dont souffre Drupal, comme 
beaucoup d’autres CMS. Les modules Views et CCK disposent de fonc- 
tions d’exportation qu’il est possible d’utiliser pour importer les nou- 
velles vues ou les nouveaux contenus sur le serveur. Mais c’est la tout ce 
qu’il est possible d’automatiser. Vous etes done contraint de refaire 
fensemble de vos parametrages a la main sur le serveur. C’est sans aucun 
doute fastidieux, mais ne cedez pas pour autant a la facilite de travailler 
directement sur le serveur, en y ajoutant de nouveaux modules ou 
themes. Vous prendriez ainsi le risque de commettre une erreur qui est 
sans consequence sur votre machine de developpement, mais qui ne le 
sera pas sur la machine de production. 

Avant de proceder a ces modifications de configuration en ligne, et pour ne 
pas perturber les visiteurs, vous devez basculer votre site en mode Mainte- 
nance. Ainsi, tous les visiteurs seront informes qu’une operation de mainte- 
nance est en cours, et ne pourront aller plus loin dans leur navigation. 

Pour activer le mode Maintenance de Drupal, il faut aller dans Configura- 
tion du site , puis Maintenance du site. La, vous cocherez l’option Hors 
ligne. Vous pouvez eventuellement modifier le message aux visiteurs : 


Elat du site : 

En ligne 
• Hors ligne 

Si vaus entre z "En ligne", tous les visiteurs pourront naviguer sur votre site normalement. Si vous 
choisissez "Hors ligne", seuls les utilisateurs avec le droit "administrer la configuration du site" pourronl 
avoir acces a votre site pour realiser la maintenance, tous les autres visiteurs verront le message du sits 
hors ligne configure ci-dessous. Les utilisateurs auto rises peuventse connecter pendant le mode "Hors 
ligne" directement via la page de connexion. 

Message dusite hois ligne : 

Colchique est en cours de maintenance. Nous serous de ret our tres bientot. 

Merci de votre patience. 
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Une fois que vous avez clique sur Enregistrer, vous etes maintenant le seul 
a pouvoir acceder au site car, pour le reste du monde, le message suivant 
s’affichera : 



Colchique car chaque brin d'herbe est unique... 


Site hors ligne 


Colrhique fist en ronrsf rifi maintfinancfi Nous sfirons Hfi retour tres hifintot 
Merci de votre patience. 


Figure 15-32 

L'ecran de maintenance pour les visiteurs 


Enfin, pour vous rappeler que le site est en mode Maintenance, Drupal 
affiche sur chaque page de fadministration le message suivant : 


Bon a savoir Revenir 

du mode maintenance grace a SQL 


Fonclionne en mode hors-licjne. 


Figure 15-33 

Le message de rappel du mode Maintenance 
active pour I'administrateur 


Vous pouvez maintenant operer les modifications, ou encore mettre a 
jour la base de donnees. Lorsque le site est operationnel, il vous suffit de 
retourner dans Configuration du Site > Maintenance du site pour rebasculer 
en mode En ligne. 


Attention a ne pas termer votre navigateur lorsque 
votre site est hors ligne sous peine d'etre vous 
aussi dans I'impossibilite d'y acceder a nouveau ! 
Si d'aventure vous vous retrouviez dans une telle 
situation, pas de panique. Connectez-vous a la 
base de donnees via phpMyAdmin et lancez les 
requetes suivantes : 

update variable set 

value=’s:l: "0" ; ’ where 

name= ’ si te_of f 1 i ne ’ ; 
delete from cache 


Performances 

Vision generate des performances 

Les bonnes pratiques des metiers de finformatique recommandent de 
prevoir les performances d un systeme informatique en amont, des la 
conception, et de faire des ajustements tout au long du developpement. 
Lorsque le projet est termine, il est souvent trop tard - dans le sens de 
« plus assez de temps » mais aussi de « plus rien a faire » - pour se preoc- 
cuper de ces aspects. Il est illusoire de croire que des optimisations de 
derniere minute pourront recuperer un site mal pense. 

Linformatique est fart de manipuler des donnees. De maniere tres sche- 
matique, les donnees doivent etre lues quelque part, puis traitees et 
envoyees autre part. La duree de tels cycles est done logiquement condi- 
tionnee par la nature des intervenants « physiques ». Ainsi, ecrire sur un 


Bon A savoir Changer I'apparence 
de la page de maintenance 

II est possible de modifier I'apparence de cette 
page pour qu'elle corresponde completement a la 
charte graphique de votre site. Pour cela, il suffit 
simplement de recopier le modele qui se trouve 
dans le dossier modul es/system/ 
mai ntenance-page . tpl . php dans votre 
theme pour pouvoir le modifier a votre conve- 
nance. 
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reseau n’a pas le meme impact quecrire en memoire ou encore sur un 
disque dur, comme le resume le graphique suivant : 
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Figure 15-34 

Les points critiques pour les performances, 
par ordre de priorite 



II est done important de minimiser ce qui est le plus lent (en rouge, en haut) 
et d’optimiser l’utilisation de ce qui est le plus rapide (en vert, en bas). Notez 
que le rang accorde au CPU ne tient pas compte d une situation oil un algo- 
rithme mal pense rendrait le traitement plus lent que sur la pire des bases de 
donnees. 

Certains elements sont composites. Une base de donnees en local sera plus 
rapide, meme en ecriture, qu une base de donnees sur un reseau tres lointain, 
mais peut etre plus lente qu une base de donnees sur un reseau beneficiant 
d une baie de disques ultrarapides, de beaucoup de memoire et de plusieurs 
CPU De nombreux facteurs conditionnent la performance finale, aussi tout 
ceci ne donne-t-il que des ordres d’idee. La seule regie qui prevaut pour 
s assurer de bonnes performances est « prevoir et verifier ». 

C’est encore plus vrai pour les applications web qui, par le nombre 
d ’intermediaires intervenant entre le navigateur de votre visiteur et votre 
code, demandent une attention toute particuliere. 

Les performances de Drupal 

Drupal est lui-meme un systeme complexe dont l’architecture modulaire 
vous permet d’etendre a finfini ses possibility de base. Mais cette extra- 
ordinaire souplesse peut aussi avoir des impacts catastrophiques sur les 
performances. Lexemple typique est donne par les requetes SQL que 
genere Drupal pour fabriquer une page. 

Pour en juger par vous-meme, utilisez le module Devel que nous avons 
installe lors de notre travail sur les themes, et activez le sous-module 
Performance Logging. Cela nous permettra d’obtenir un rapport sur les 
requetes SQL generees, mais aussi sur l’occupation memoire et le temps 
de creation de la page. 

Pour parametrer ces fonctionnalites, allez dans Configuration du site > 
Devel Settings. Dans la section Query Log , cochez Collect query info. 
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0 Collect query info 

Collect query info. If disabled, no query log functionality 

□ Afficher la liste des requetes. 

Display a log of the database queries needed to general 
view are summed in the# column, and printed in red sin 

Sortquery log : 

® by source Figure 15-35 

O by duration Le parametrage des requetes du module Devel 

Dans la section suivante, cochez Afficher le chronometre de page et Display 
memory usage. Vous pouvez desormais enregistrer et retourner sur la 
page d’accueil. 

En bas de la page, vous devriez voir apparaitre une ligne de statistiques 
generales. 


Page execution time was 866.67 ms. Executed 154 queries in 273.23 milliseconds. 

Memoiy usage: 

Memory used at: d eve IJnitO =0.32 MB, d eve l_shutd own 0=6.31 MB. 


Figure 15-36 

Les performances de notre systeme 


Nous voyons ici que le temps de fabrication de la page est de 
866 microsecondes et que cette fabrication a necessite l’execution de 
154 requetes qui ont occupe la machine pendant un peu plus d’un tiers 
de ce temps de creation (273 microsecondes). Les temps peuvent vous 
sembler importants, mais n’y pretez pas trop attention, car nous ne 
sommes pas sur un serveur mais une machine de developpement. Les 
chiffres qui comptent vraiment sont le nombre de requetes et le rapport 
entre le temps pris par celles-ci et le temps total passe (dans notre cas, un 
tiers du temps total). 

Allons maintenant dans le panneau de configuration des modules, et 
desactivons workflow , node access, five star et votingapi. Revenons ensuite 
sur la page d’accueil et observons les chiffres : 


Page execution time was 961.83 ms. Executed 153 queries in 238.49 milliseconds. 

Memory usage: 

Memory used at: d eve l_i n itQ =0.31 MB, d eve l_shutd own 0=6.07 MB. 


Figure 15-37 

Les performances de notre systemes 
avec quelques modules en moins 


Le nombre de requetes n’a pas beaucoup change (juste une de moins) ; 
en revanche, le temps pris par les requetes a nettement baisse (un quart 
au lieu d’un tiers). 
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L’explication tient justement de la nature modulaire de Drupal. En effet, 
Workflow et Node access n’ajoutent pas beaucoup de requetes, mais 
modifient les requetes faites par d’autres modules, notamment celles du 
module Node. Par exemple, Node access ajoute une serie de jointures 
pour restreindre eventuellement raffichage du contenu en fonction des 
droits de la personne qui affiche la page. 

La consequence est que le nombre de requetes ne change pas, mais que 
celles-ci deviennent de plus en plus lourdes. Et ceci est encore plus 
marque avec des modules prenant en charge les reseaux sociaux comme 
User relationship. 

En resume, le danger des modules reside avant tout dans leur simplicity 
d ’installation, et done dans leur multiplication, alors que le besoin n’est 
pas toujours reel. Combien de sites ont active des modules comme Node 
access ou Workflow uniquement pour les tester, mais ne les ont jamais 
desactive par la suite ? Les bonnes performances de Drupal sont done 
assurees en partie par une bonne hygiene dans votre gestion des 
modules : n’activez que ce dont vous avez besoin. 

Pensez egalement a verifier grace a Devel le nombre de requetes gene- 
rees et la proportion temps SQL/temps de creation. Des que vous 
detectez un ratio excessivement eleve, retournez dans la configuration 
Devel Settings et activez l’option Afficher la liste des requetes et Sort query 
log by duration. Vous obtiendrez ainsi sur chaque page la liste des 
requetes generees, avec en tete celles qui sont les plus longues. 


Executed 163 queries in 243.36 milliseconds. Queries taking longer than 5 ms and queries executed more than once, are highlighted. 
Page execution time was 860.72 ms. 



ms 

# 

where 

query 

Figure 15-38 

Rapport des requetes produit 

2L3 

1 

cache_set 

UPDATE e u.c he t'i 1 Lcr SET diiLu = ’<p>Les administrate urs nlfceac li teiseau n 

connaiKsenL t-ils la crise ?<fp>Wl 2'. created = 1 2460 2 S60 3. est pine = 

124611500.1, headers = .serialized =0 WHERE cid = 

'1 : 2cd4777 2 S uc3 b b4697 3c74 a 9 39d 25d99‘ 

par le module Devel 

9.66 

1 

modulejist 

SELECT name, filename. throttle FROM system WHERE type = 'module AND 
5taLus= ,1 AND bootstrap = 1 ORDER BY weighL ASC, filename A5C 


Ameliorer les performances du serveur 

Gestion des caches 

Ceci etant dit, si vous desirez construire un site avec flux de travaux, droits 
d’acces par utilisateur, reseaux sociaux et blogs, il est bien evident que les 
requetes seront nombreuses et denses, sans que vous puissiez faire grand 
chose pour les reduire. Notez seulement que vous avez aussi la possibility 
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de developper ou de faire developper des modules tallies au plus pres de 
vos besoms, et done plus optimises pour un site complexe a fort trafic. 

Drupal dispose neanmoins de plusieurs parades efficaces lui permettant 
de rester tres performant malgre le nombre de requetes imposees par les 
modules. La premiere de ces techniques est son systeme de cache, qui est 
un element crucial pour ameliorer les performances. 

Son principe est tres simple : lorsque Drupal ou un module doit faire 
une operation qui risque d'etre couteuse en temps a cause d un nombre 
important de requetes SQL, il verifie d’abord si ce travail n a pas deja ete 
realise et place alors en cache. Si e’est le cas, il saute 1’etape en question 
pour utiliser directement la valeur presente dans le cache. Si ce n est pas 
le cas, il effectue le calcul et y stocke le resultat. 

De nombreux caches sont ainsi utilises par Drupal : 

• le cache de page, qui permet de renvoyer quasi instantanement une 
page complete qui a deja ete generee ; 

• le cache des formats d’entree, dans lequel les contenus formates par 
les formats d’entree sont stockes ; 

• le cache des blocs, qui permet de ne pas recalculer systematiquement 
chaque bloc dune page ; 

• le cache des menus, utilise par Drupal pour ne pas avoir a systemati- 
quement passer en revue les menus declares par les modules ; 

• le cache des contenus, utilise par CCK ; 

• le cache des vues, utilise par Views. 

La majeure partie de ces caches fonctionne sans que vous n’ayez rien a 
faire. Le cache de page constitue la seule exception, mais il est aussi le 
plus efficace de tous. Il permet en effet de Stocker l’ensemble d’une page 
de maniere a ce qu’elle engendre un temps de creation a peu pres nul les 
fois suivantes. C’est bien simple : lorsque ce cache de page est active, il 
faut moins de 10 requetes SQL pour generer une page, et ceci avec un 
nombre tres limite de modules charges en memoire. 

Ce systeme de cache de page permet d’obtenir des performances equiva- 
lentes a un site en XHTML statique, avec une seule 
contrainte, cependant : il ne fonctionne que pour les visiteurs anonymes. 

En effet, il peut y avoir beaucoup trop de changements entre une page 
d’un utilisateur identifie et celle d’un autre (son menu de navigation, ses 
blocs, son theme, etc.) pour qu’on puisse utiliser le cache de page sans 
risque. Ceci etant dit, dans la majorite des cas, vos visiteurs seront ano- 
nymes et le cache de page liberera ainsi autant de temps machine pour 
ceux qui sont identifies. 
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Figure 15-39 

Fonctionnement du cache de page 



Parametrage du cache 

Par default, le cache de page est desactive et, pour changer cela, il faut 
aller dans Configuration du site > Performances. C’est d’ailleurs a cet 
endroit que se regie la majorite des aspects lies aux performances que 
nous allons aborder. 

La premiere etape est done d’activer ce cache de page en choisissant lun 
de ses trois modes de fonctionnement : 


Figure 15-40 

Les trois modes de fonctionnement 
du cache de page 


Mode de cache : 

Desactive 

* Normal (recorn m and e en production, pas d'effets second ai res) 
Agressif (experts seulement, effets second ai res possibles) 


La difference entre les modes Normal et Agressif vient de la maniere dont 
sont pris en charge les modules lorsquune page est deja en cache. En 
mode Normal, un certain nombre de modules qui en ont fait la demande 
sont demarres. En mode Agressif, plus un seul module nest utilise. 


382 


www.frenchpdf.com 




T3 

O 

Les modules que Drupal indique comme etant incompatibles avec le 
mode Agressif ont generalement besoin de commencer a travailler tres tot, 
par exemple pour changer le theme en fonction de l’adresse ou du type de 
navigateur (ex : Mobile tools pour faire un Drupal optimise pour les 
mobiles). Ceci etant dit, il ne s’agit que d un risque d ’incompatibilite ; le 
mieux est done de tester et de verifier prealablement. 

Juste apres la selection du mode de cache arrive la duree de vie du cache. 

De maniere automatique, le cache Page est vide a chaque modification de 
contenu ou lors de l’ajout d un commentaire. II serait done logique d ’indi- 
quer ici la plus haute des valeurs, a savoir 1 jour , mais ce serait oublier que 
certains blocs, par exemple la liste des utilisateurs en ligne, ne provoquent 
pas de leur propre chef- et fort heureusement - de vidange du cache Page. 

Finalement, cette valeur doit etre reglee au temps qui vous semble raison- 
nable pour que de tels blocs soient a jour, par exemple, 30 minutes est une 
valeur raisonnable pour un site a moyen trafic. 

Duree tie vie minimale de la memoire cache : Figure 1 5-41 

30 min c ] Reglage du temps de vie du cache Page 


Pour conclure sur le sujet des caches, vous avez aussi la possibility 
d’activer ici le Cache des blocs. C’est en general une bonne idee, car cela 
ameliorera sensiblement les performances, surtout si vous utilisez beau- 
coup de blocs et que ces derniers induisent de nombreuses requetes. 


Cache des hlocs : 

O Desactive Figure 15-42 

III Active (recommande) Activation du Cache des bloCS 

Accelerateurs de code PHP 

Une autre maniere d’ameliorer tres sensiblement les performances de 
Drupal, ou dune application PHP en general, est d utiliser un accelera- 
teur PHP. Le principe est tres proche de celui du cache. Au lieu d’inter- 
preter a chaque page le meme code PHP, l’accelerateur cree la premiere 
fois une version plus compacte et plus rapide qu il stockera en memoire. 

Les fois suivantes, le code « optimise » est directement execute en 
memoire et ne demande ainsi plus d’acces au disque. Les gains de per- 
formance sont tres importants, surtout pour Drupal, avec ses milliers de 
lignes de code PHP. 

Ce type d’outil s’installe en general comme un module pour le service 
Apache et ne demande absolument aucune administration dans Drupal. 

Il existe plusieurs outils de cette sorte comme eAccelerator 
(http://eaccelerator.net/), XCache (http://xcache.lighttpd.net/) ou encore APC 
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Bon a savoir 

Booster les performances d'APC 

APC verifie systematiquement si les fichiers PHP ont 
ete modifies pour eventuellement les recompiler et 
mettre ainsi a jour son cache. Cette approche 
permet de prendre en compte toute modification du 
code PHP au detriment des performances, car cela 
implique un acces disque pour chaque fichier, et 
comme Drupal en compte des milliers... 

La solution a appliquer en serveur de production est 
de modifier le parametrage d'APC et de desactiver 
cette fonctionnalite (parametre ape . stat = 0). 
Vous gagnerez ainsi en performance, mais en con- 
trepartie vous devrez utiliser I'interface d'adminis- 
tration d'APC pour mettre a jour vous-meme le 
cache lorsque vous modifiez le code de Drupal sur le 
serveur. 


URL Module Cache Router 

► http://drupal.org/project/cacherouter 


Bon A savoir 

Utilisez la memoire de vos serveurs 

Comme vous I'aurez remarque sur la page de 
projet du module Cache Router, ce dernier permet 
aussi d'utiliser les caches File et Memcache. Le 
premier mode consiste simplement a Stocker le 
cache en tant que fichier. C'est moins rapide que la 
memoire mais plus rapide que la base de donnees, 
a utiliser si votre serveur n'a pas assez de memoire 
disponible. L'autre mode permet d'utiliser un ser- 
veur de memoire appele Memcached (http:// 
www.danga.com/memcached/). Ce serveur 
permet d'utiliser la memoire d'une machine qui se 
trouve sur le reseau a partir d'une ou plusieurs 
autres machines. C'est un outil de predilection 
pour les sites a tres haut trafic heberges sur des 
grappes de serveurs. 
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(http://us.php.net/apc). II est communement admis qu’APC est un systeme 
qui a prouve sa robustesse et ses performances. 

Le cache de Drupal en memoire 

L’ autre avantage des accelerateurs de code PHP est qu’ils fournissent aux 
applications ecrites en PHP la possibility de Stocker des donnees arbi- 
trages dans une memoire partagee, ce qui peut la aussi enormement 
booster les performances de notre Drupal. 

En effet, nous avons maintenant bien compris comment le cache de 
Drupal fonctionne, mais nous n avons pas encore pris connaissance de 
fendroit oil sont stockees ces donnees. La reponse - qui peut sembler un 
peu paradoxale - est : en base de donnees. II devient par consequent evi- 
dent que notre site serait beaucoup plus rapide si ces donnees etaient 
stockees en memoire (en utilisant par exemple APC), et nous aurions 
tort de nous en priver tant ceci est facile a mettre en place. 

II nous suffit pour cela d ’installer le module Cache Router. Ce module 
permet de remplacer le stockage par defaut du cache en base de donnees 
par un stockage en memoire via APC, eAccelerator ou XCache. 

Une fois le module installe (il n’est pas necessaire de l’activer), editez le 
fichier de configuration setti ngs . php et ajoutez-y les lignes suivantes : 

Activation de Cache Router dans settings.php 

$conf [ ' cache_i nc ' ] = ' ./sites/all /modules/contrib/cacherouter/ 
cacherouter . i no' ; 

$conf [ ' cacherouter ' ] = array( 

'default' => array( 

'engine' => 'ape', 

' server ' => arrayO , 

'shared' => TRUE, 

'prefix' => 'colchique', 

), 

); 

La premiere ligne permet a Drupal d’utiliser le module Cache Router 
pour sa gestion du cache. Veillez a bien verifier que le chemin est le bon, 
sinon votre site ne fonctionnera plus ! Le bloc suivant indique que les 
donnees du cache de Drupal doivent utiliser APC ( ' engi ne ' => ' ape ' ). 

II suffit de sauvegarder le fichier (et de s’assurer bien evidemment 
qu’APC est installe et active) pour que le nouveau stockage du cache soit 
automatiquement pris en compte. Dans la mesure oil beaucoup de don- 
nees seront ainsi stockees en memoire, vous pouvez aussi augmenter 
l’espace de RAM allouee a APC. Pour cela, vous devez modifier le para- 
metre apc.shm_size, par exemple ape . shm_si ze=2 56 pour allouer 
256 Mo au cache APC, et done a Drupal. 
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Accelerer le journal 

Comme nous l’avons mentionne au tout debut de cet ouvrage, Drupal 
ecrit dans un journal (appele Watchdog) de tres nombreuses informations 
sur son fonctionnement. Ces informations sont disponibles en allant 
dans Administrer > Rapports > Tableau de bord. 

Le probleme de performance induit par ce systeme reside dans le fait 
que ces informations sont ecrites en base de donnees, ce qui prend obli- 
gatoirement du temps. Ce stockage est pris en charge par le module 
standard de Drupal Database logging. 

Sur les systemes Unix, il est conseille d’utiliser le module Syslog fourni en 
standard, et de desactiver le module Database logging. Ainsi, votre systeme 
necrira plus rien en base de donnees, mais utilisera le demon Unix Syslog 
local a la machine, et qui est con^u des l’origine pour la performance. 

L’inconvenient est que les erreurs ne seront plus accessibles par finterface, 
mais seulement par visualisation des journaux du systeme Unix. 

Ameliorer les performances du navigateur 

Compression des pages 

Une fois les performances du serveur optimisees, il est possible de passer 
encore un peu de temps a ameliorer celles du navigateur. Cela corres- 
pond avant tout a reduire au maximum le volume de donnees qu il 
echange avec le serveur. 

La compression des pages, le dernier avantage de roptimisation, est le 
fait qu un navigateur web qui respecte les standards ne depassera pas 
quatre telechargements a la fois. Si nous avons douze feuilles de style, le 
navigateur lancera done un premier groupe de quatre telechargements, 
attendra qu’ ils s’achevent et recommencera ainsi deux fois de suite en 
perdant a chaque fois le temps d’initialisation de la connexion. 

Notez, que l’optimisateur de feuilles de style ne fonctionnera que si vous 
avez correctement declare vos fichiers CSS dans votre fichier 
mon_theme . i nfo. 

Optimisation des feuilles de style 

Les scripts et les feuilles de style represented de nos jours la majeure 
partie de ce qu’un navigateur a besoin de telecharger pour obtenir une 
page complete. Chaque module et theme pouvant potentiellement 
declarer ses propres styles, ce sont tres rapidement des dizaines de ces 
feuilles qui sont ainsi liees a une page. Pour s’en convaincre, nous pou- 
vons utiliser l’onglet Reseau de Firebug : 
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Figure 15-43 

L'onglet Reseau du module Firebug 


0 GETwww.colchique-conseil.fi 

200 OK 

0 GETadmin_menu.css?g 

200 OK 

0 GET node.css?g 

200 OK 

0 GETdefaults.css?g 

200 OK 

0 GET system css?g 

200 OK 

0 GET system- men us.cssOg 

200 OK 

0 GET user.css?g 

200 OK 

0 GET content- mod ule.css?g 

2C0 OK 

0 GET date.css?g 

200 OK 

0 GET dalepicker.nss^g 

200 OK 

0 GET timeentry,css?g 

200 OK 

0 GETsimplenews.css?g 

200 OK 

0 GET fieldgioup.css?g 

200 OK 

0 GET style.css?g 

200 OK 

0 GET elements- html.css?g 

200 OK 


colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 

colchique-conseil.fr 


31 KB 
4 KB 
740 B 

757 B 
10 KB 
935 B 

2 KB 

3 KB 

4 KB 
4 KB 

509 B 
610 B 
166 B 
6 KB 

758 B 


Comme vous le voyez, avec pres de 4 Mo cumules, le volume de ces 
feuilles de style n est pas, loin de la, negligeable et rend ridicule les quel- 
ques 31 Ko de la page XHTML. 

C’est pour cela que Drupal integre un optimisateur de feuilles de style, 
dont le principe est de fabriquer une « super feuille de style » dans 
laquelle est ajoute le contenu de chacune des feuilles presentes, puis de la 
compresser, c’est-a-dire de la debarrasser de toutes les choses inutiles 
(commentaires, sauts de ligne, etc.). Pour activer cette fonction, toujours 
dans le panneau Performances , il suffit de changer la valeur de Optimise 
lesfichiers CSS a Active. 

Figure 1 5-44 Optimise les fichiers CSS : 

Activation de I'optimisation o Desactive 

des feuilles de style ® ActiV e 


Ceci fait, enregistrez la configuration et retournez sur la page d’accueil 
pour juger du resultat avec Firebug : 


Figure 15-45 

Le reSUltat est pour le moins O GETad5577ft^2ffd49b1b4c47e3d 20GOK colchique-consoil.fr 22KB 

convaincant, n'est-ce pas ? 


Bonne pratique L'optimisateur de code CSS 

II existe un outil particulierement pratique appele 
CSSTidy dont le but est de reduire la taille des 
fichiers CSS par une reorganisation interne. Selon 
le parametrage de I'outil, I'optimisation peut aller 
du simple nettoyage, permettant d'obtenir un code 
plus lisible et maintenable, a une compression 
proche de ce que permet Drupal. II est done plus 
interessant de I'utiliser en mode nettoyage. 

► http://csstidy.sourceforge.net/ 


Outre la diminution du temps de chargement induite par cette reduction 
de taille, foptimisation des feuilles de style vous permet de commenter 
proprement le code CSS sans risque d’impact sur les performances. 

Optimisation des scripts 

Drupal propose la aussi un systeme d’optimisation des scripts reposant 
sur le meme principe que celui des feuilles de style. Ceci est d’autant plus 
interessant qu un navigateur comme Mozilla Firefox ne charge pas les 
scripts quatre par quatre, mais juste un a la fois. 
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© GET jquery.JsTC 

200 OK 

© GET dnipal.js?C 

200 OK 

E GETfr_993fe8e085319526e887cb< 

200 OK 

© GETadmin_menu.js?C 

200 OK 

© GET jquery.curvycomeis, packed. 

200 OK 

© GET ui.Js?C 

200 OK 


colchique-conseil.fr 

31 KB 

colchique-conseil.fr 

10 KB 

colchique-conseil.fr 

3 KB 

colchique-conseil.fr 

2 KB 

colchique-conseil.fr 

13 KB 

colchique-conseil.fr 

208 B 


Figure 15-46 

Les scripts charges les uns apres les autres 
par Mozilla Firefox 


© 
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Comme pour les feuilles de style, roptimisation des scripts supprimera 
les commentaires, les espaces en trop, et fabriquera un script unique qui 
se telechargera done plus rapidement. 

Pour activer roptimisation des scripts, activez comme pour les styles la 
zone correspondante du panneau de gestion des performances : 


Optimise les fichiers Javascript : 

O Desactive 
® Active 


Figure 15-47 

Activation de roptimisation des scripts 


Vous pouvez ensuite juger du resultat avec Firebug : 


© GETe532Bced26fOae258c9543&2e 200 OK colchique-conseil.fr 57 KB 

Figure 15-48 II n'y a plus qu'un seul fichier JavaScript de taille reduite. 


Modules magiques Compressez vos JavaScript 

Si vous comptez beaucoup de scripts, une autre pos- 
sibility est d'utiliser le module JavaScript Aggre- 
gator. Ce dernier fait la meme chose que le systeme 
natif de Drupal en ajoutant en plus I'utilisation de 
JSMin, un outil evolue de compression de script. A 
vous de tester cette approche si vous considerez le 
script produit par Drupal encore trop gros. La proce- 
dure d'installation est simple et lisible sur la page de 
projet du site. Ce module est aussi la seule option 
de compression de scripts que vous avez, si vous 
devez encore travailler avec Drupal 5. 

► http://drupal.org/project/ 
javascript_aggregator 

► http://code.google.eom/p/jsmin-php/ 


L’impact est moins flagrant que pour les styles, mais reste appreciable 
pour minimiser le nombre de connections. 


Vidange des caches 

L’activation de toutes ces optimisations nest pas une bonne chose sur 
une machine de developpement, car elles ajoutent une couche de com- 
portement qui rend delicat les tests et autres debogages. 

De meme, les caches et autres techniques d’optimisation peuvent egale- 
ment nous gener sur une machine de production pour valider certains 
parametrages. II est done necessaire de pouvoir en faire la purge quand le 
besoin s’impose. 

Pour vider les caches du cote serveur, vous avez sur la page de gestion des 
performances en fin de formulaire un bouton prevu a cet effet : 


Supprimer les donnees du cache 

Utiliser la fonction de cache augmente les pe 
si des informations sont mises en cache. Po 
fonctionnemenl des sties a ton irafic peui rate 
[ Supprimer les donnees du cache 


Figure 15-49 

Bouton de vidange des caches de Drupal 
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Bon A SAVOIR Vidage de cache 
en ligne de commande 

Le module Drush, que nous avons vu un peu plus 
haut, permet d'operer en ligne de commande une 
vidange complete des caches, ce qui se revele etre 
plus que pratique en phase de test ou I'operation 
doit etre sans cesse renouvelee : 

./drush cache clean 


Modules magiques Le cron du pauvre humain 

Si vous ne pouvez ou ne voulez pas utiliser le pla- 
nificateur de tache de Windows ou le cron Unix, il 
vous reste I'option du module Poormanscron. Ce 
module lance le cron Drupal selon une frequence 
parametrable en profitant de la requete d'un de 
vos visiteurs. 

Ce systeme ne ralentit pas I'utilisateur, car son 
execution se fait apres avoir envoye la page au 
navigateur client. En revanche, si vous avez un tres 
faible trafic, il se peut que la frequence ne soit pas 
respectee. 

► http://drupal.org/project/poormanscron 


Il suffit d’appuyer sur ce bouton pour vidanger l’ensemble des caches, y 
compris les scripts et feuilles de style optimisees. Attention cependant a 
ne pas abuser de ce bouton sur un site qui re^oit beaucoup de monde, car 
vous allez obligatoirement creer un ralentissement le temps que les 
caches se reforment. 


Cron 

Jusqu’a maintenant, nous gerions le lancement du cron de Drupal a la 
main en utilisant cron . php dans le navigateur. En production, il va nous 
falloir trouver un moyen plus automatique pour lancer ce script vital a 
toute installation Drupal. 

Sous Unix, qui est le systeme d’exploitation majoritairement utilise pour 
un site web public, la solution ideale pour activer le cron de Drupal est 
d utiliser le demon crond. 

Cela consiste a ajouter dans le dossier /etc/crond.d, une nouvelle table 
cron semblable a celle-ci : 

#!/bi n/bash 

# /etc/cron . d/php : crontab pour Drupal 

# Look for and purge old sessions every 30 minutes 

*/15 * * * * root /usr/bi n/lynx -source http : //www. col chi que- 
conseil.fr/cron.php > /dev/null 2>&1 

Le principe est ici d utiliser l’utilitaire Lynx, un navigateur web en ligne 
de commande present sur toutes les distributions, pour aller chercher la 
page cron . php et ainsi declencher le cron de Drupal. Notez que la meme 
chose est realisable avec wget. 

Sous Microsoft Windows, faffaire se complique un peu. En effet, d une 
version a l’autre, les choses ne fonctionnent pas de la meme maniere, du 
moins pour l’aspect graphique. Heureusement, il est possible de pro- 
grammer le planificateur de taches en ligne de commande. Le principe 
est ici d utiliser Mozilla Firefox pour aller chercher la page cron . php. 

C:\> schtasks /create /tn "Drupal Cron Job" /tr "c:\Program 
Fi 1 es\Mozi 1 1 a Firefox\firefox.exe http : //www. col chi que- 
conseil.fr/cron.php" /sc hourly 

La commande vous demandera alors le nom et Tidentifiant de l’utilisa- 
teur qui lancera le processus : 
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La tache va etre creee sous le nom de 1 ’ uti 1 i sateur local 
actuellement connecte 
( ,, A-283AE68F6F5F4\Gaston M ) . 

Entrez le mot de passe pour A-283AE68F6F5F4\Yoran dans 
"Executer en tant que" : 


Une fois la commande correctement lancee, le planificateur de tache 
executera le cron de Drupal toutes les heures. 


Bon A savoir Comment etre certain 
que le cron est operationnel ? 

Dans un premier temps, pour verifier que le cron 
fonctionne, vous pouvez creer une action 
« Envoyer un courriel a » en I'associant au deden- 
cheur Lancement de cron. Vous serez ainsi notifie 
par courriel a chaque lancement du cron. Lorsqu'il 
est etabli que le cron fonctionne, vous pouvez sup- 
primer cette regie. 


Gerer le multisite 

Nous avons cree notre premier site Drupal, et cela peut vraisemblable- 
ment donner envie d’en creer d’autres. La question de faire coexister plu- 
sieurs sites Drupal sur une seule et meme machine peut alors se poser. 

Comme vous l’avez vu, toute la configuration pour Drupal se trouve 
dans la base de donnees. II peut done sembler legitime d’imaginer un 
meme Drupal avec plusieurs bases de donnees, chacune pour un site dif- 
ferent, et e’est tres exactement ainsi que cela se fonctionne. 

Toute la magie tient dans le seul dossier sites dont nous n avons jusqu’a 
maintenant utilise que deux sous-dossiers : default qui contient notre 
configuration setti ngs . php, et all qui contient nos themes et nos 
modules. Imaginons a present que nous voulions ouvrir un second site 
http://www.colchique-conseil.fr/blogs/marine, que Marine utilisera comme son 
blog personnel. 

II faut alors que Drupal puisse trouver une nouvelle configuration 
setti ngs . php, lui permettant d utiliser la seconde base de donnees. Pour 
cela, il recherchera comme le fait PHPEngine dans le dossier sites, 
parmi une liste de noms de dossiers eligibles. 

• www. col chique-consei 1 .fr. blogs. marine : nous avons ici fadresse 
complete du site en rempla^ant juste les slashs par des points. 

• col chi que-consei 1 . f r . bl ogs . mari ne : la meme chose, mais cette fois 
en otant le sous-domaine www. 

• f r . bl ogs . mari ne : ici, Drupal enleve le domaine pour ne laisser que le 
domaine de premier niveau (fid, pour top-lev el- domain) et le chemin. 

Si aucun dossier eligible nexiste dans le dossier sites, Drupal recom- 
mence, mais cette fois en enlevant le dernier dossier, ce qui nous donne : 

• www. col chique-consei 1 .fr. blogs ; 

• col chique-consei 1 .fr.bloc ; 

• fr. blogs. 
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Vous l’avez maintenant compris : si Drupal ne trouve toujours pas de dos- 
sier, il recommence, mais cette fois sans aucun sous-dossier dans 1TJRL : 

• www.colchique-conseil.fr; 

• colchique-conseil.fr; 

• fr. 

Enfin, si rien na marche, il se rabat sur le sous-dossier default. C’est 
pour cela que nous pouvions jusqu’a maintenant l’utiliser. 

Pour que nos deux sites fonctionnent, il faut done commencer par recopier 
defaul t vers un dossier col chi que-consei 1 . f r. Ainsi nous aurons le meme 
comportement qu avant. Notez au passage que ne pas specifier le www per- 
mettra a notre site de fonctionner correctement lorsque nous disposerons 
d une version « mobile » de la forme http : //mobi 1 e . col chi que-consei 1 . fr/. 

Creons ensuite un nouveau dossier col chi que-consei 1 .fr. blogs, 
mari ne , et allons y recopier le fichier setti ngs . php provenant du dossier 
default. 


y 

Drupal 
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Figure 15-50 

Le blog de Marine 


Figure 15-51 

Le site Colchique dassique 


► Choose language 

Verify requirements 
Set up database 
Install site 
Configure site 
Finished 


Choose language 

° ilnstall Drupal in English; 

° Learn how to install Drupal in other languages 


Nous void avec un site vierge que nous pouvons installer et parametrer 
comme le premier, et qui n entre pas en conflit avec lui. Pour preuve : en 
allant cette fois sur http://www.colchique-conseil.fr/, nous voila de nouveau sur 
le site que nous connaissons bien : 


22 Colchique 

Car ebaque brin d'herbe est unique... 


Nos Publications Les Billets FAQ 


Etat du marche de I'emploi pour les Administrateurs reseaux 

Soumis par Marine le dim „ Q&H/OQOS - 10:30 

Les administrateurs reseaux connaissentt-ils la crise ? 
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II est possible (Taller plus loin encore, en disposant de modules et de 
themes specifiques par site. Pour cela, il suffit de creer dans le dossier de 
chaque site une arborescence modules et themes et d’y decompresser les 
archives, comme dans le dossier al 1 . Tout ce qui se trouvera dans le dos- 
sier d un site ne sera vu que par lui. 

Ceci nous permet de comprendre lutilite du dossier al 1 que nous utilisions 
jusqu alors, car tout ce qui s y trouve est visible pour l’ensemble des sites. 


Modules magiques Partagez vos contenus 
entre plusieurs sites 

Une autre maniere d'utiliser la meme installation 
Drupal pour plusieurs sites est d'utiliser le module 
Domain Access qui permet egalement de partager 
la meme base de donnees. Le domaine d'utilisa- 
tion n'a plus rien a voir ici et presente I'avantage 
de permettre le partage de contenus entre plu- 
sieurs sites. 

► http://drupal.org/project/domain 


En resume 

• Pensez a consulter regulierement les mises a jour disponibles (ou 
encore mieux, faites-vous prevenir), il en va de la securite de votre 
site. 

• Il ne suffit pas de mettre a jour le code, il faut aussi mettre a jour la 
base de donnees. 

• Testez, testez et testez encore sur votre machine de developpement, 
ne jouez jamais a fapprenti sorcier sur un serveur en production. 

• Les performances sont a optimiser sur le serveur de production : rien 
ne sert d’appliquer des reglages de performance sur votre machine de 
developpement, vous ne feriez que vous compliquer la tache. 

• N’oubliez pas d’activer le lancement automatique du cron de Drupal. 
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Un regard sur Drupal 7 


Drupal 7 nest pas encore sorti mais les contours de cette 
nouvelle mouture commencent a se preciser. Rassurez-vous, 
aucun de vos acquis ne sera remis en cause par cette version 
qui se place dans la continuity de la philosophie de Drupal. 
Elle apportera trois evolutions majeures et plusieurs autres 
ameliorations, avec pour objectif commun de rendre Drupal 
plus simple a utiliser tout en ameliorant ses performances et en 
l’ouvrant a d’autres systemes de bases de donnees. 


SOMMAIRE 

► Decouvrez les prochaines 
ameliorations ergonomiques 

► CCK directement dans le coeur 
de Drupal ? 

► Un nouveau moteur de base 
de donnees 

► Et de nombreuses autres 
nouveautes... 
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Modules magiques Trop impatient 
pour attendre Drupal 7 ? 

Eh bien, rejouissez-vous car il existe un module 
Vertical Tabs qui permet de doter Drupal 6 de cette 
merveilleuse amelioration ergonomique pour I'edi- 
tion des contenus. 

► http://drupal.org/project/vertical_tabs 


Amelioration de I’ergonomie d’utilisation 

La premiere chose que vous noterez en decouvrant Drupal 7 sera tres pro- 
bablement la grande amelioration de l’ergonomie d ensemble. Ce sujet est 
devenu un enjeu a part entiere, au point de lui dedier pour cette nouvelle 
version une equipe de travail exclusive (http://groups.drupal.org/usability). 

Pour prendre un exemple, si les interminables series de sections deplia- 
bles - typiquement sur la page d’edition des contenus - vous rebutaient, 
vous vous rejouirez sans nul doute du nouveau mode de presentation par 
onglets verticaux. Plus agreable et surtout beaucoup plus compact, ce 
nouveau mode de presentation vous permettra de selectionner les diffe- 
rents groupes de reglage en quelques dies. 


Menu settings 
Not in menu 


Changes made to the attach ments are not permanent until you save this post. The first 'listed' file will be included in 
RSS feeds. 


Figure 16-1 

Le nouveau mode de 
presentation des reglages 
par onglets verticaux 


Revision information 
No revision 

File attachments 

0 attach ments 

URL path settings 
No alas 

Comment settings 
Closed 

Authoring information 
By administrateur 

Publishing options 
Published 


Delete 

List 

Description 

Size 

□ 

© 

[Getting Things Done.pdf 

] 2.13 

http:. 1 . ’dew .dxpa l7.karma-bb.net si tes, default' n les.'Getting T lings Daie.pdl 

MB 


Attach new file: 

Parcourir. .. 

The maximum size of file uploads is t MB. Only files with the following extensions may be up loaded : jpg jpeg gif png ftef 
doc yls pdf ppt pps oat ods odp. 

Attach 


Toujours dans l’optique d’amdiorer l’ergonomie de l’edition des con- 
tenus, la sdection des formats d’entree a ete grandement simplifiee. Les 
boutons radio ont disparu au profit dune liste deroulante qui, lorsque 
vous sdectionnez un format, affiche dynamiquement faide associee. 


Figure 16-2 

Selection des formats de texte 


Text format: ( Filtered HTML C I 


Web page. 
Allowed 


Filtered HTML 
Full HTML ^ 


Jr 


turn into lin Is automatically. 

<erf?>^trong> <cite> <bbckquote> <eode> <ut* ^ot> <lt> <dl> <dt> <dd> 


Lines and paragraphs break automatically. 


De meme, le terme de « format d’entree » a ete remplace par « Text 
format » (format du texte), ce qui est tout de meme plus coherent. 

Dans le meme esprit, un systeme d’aide avancee a ete integre. II est ainsi 
possible de disposer d’informations detaillees sur un dement de l’inter- 
face en cliquant sur l’un des points d’interrogation sur fond bleu. 


394 


www.frenchpdf.com 


□ 

0 

Book 

Color 

7.x-dev 

7.x-dev 

Allows users tuuieuteanJuiL^nike lekileUcuiiteii ittaiiuulirte. 

Allows administrators to change the color scheme of compatible themes 

O ' loro 

Figure 16-3 

Presentation 

0 

Comment 

7.x-dev 

Allows users to comment on and discuss published content 

Required by: Forum disabled i Tracker disabled i 

Q More he^3 

de I'aide avancee 


De nombreux petits details ont egalement evolue, et continueront de le 
faire jusqu’a la version finale, afin de toujours ameliorer futilisation : 

• le menu d’administration contient davantage de sous-categories, 
comme la Gestion des langues ; 

• le choix du theme d’administration a ete place dans l’administration 
des themes ; 

• une explication est placee a cote des permissions pour en expliquer 
l’usage ; 

• notre astuce du role Administrates pour deleguer l’administration 
du site est devenu une fonctionnalite officielle. 


Integration de CCK 

Vous l’avez certainement compris, CCK est un module indispensable a 
Drupal et c’est pourquoi Drupal 7 l’integrera, du moins en partie. 

Le principe choisi est de garder le module CCK pour l’aspect graphique 
de l’edition des types de contenu, et d’integrer intimement la gestion 
interne des champs au coeur meme de Drupal. 

Cette nouvelle fonctionnalite s’appellera FieldAPI. Elle fonctionnera 
done comme l’actuel CCK en y ajoutant de nouvelles fonctionnalites, 
comme pouvoir changer dynamiquement le type d’un champ. 

Mais FieldAPI va plus loin encore. Etant directement integre a Drupal, 
il distribuera ses bienfaits sur l’ensemble du systeme entrainant la dispa- 
rition de la frontiere entre les champs natifs d’un contenu et les champs 
ajoutes. Tous les champs d’un contenu (titre, taxonomie, menu, etc.) 
pourront des lors etre manipules comme s’ils etaient des champs CCK. 

Alti C 1 0 Edit 0 i sp I a/ file Ids 

Add field to the Co nte nt type, and a rra age the mon content di s pi ay a nd in put for 
You can add a field to a group by dragging it below and to the right of the group. 

Label Name Field 

Title Node module element. 

4* Taxonomy Taxonomy module element 

*jr Menu settings Menu module element. 

’f* File attachments U ptu ad n ludu le ete 1 1 ta i il. 


Figure 16-4 

Tous les champs natifs deviennent des champs CCK. 
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Enfin, FieldAPI sera aussi utilise pour toutes les donnees du systeme qui 
n etaient pas encore vues comme de reels contenus. C’est notamment le 
cas des commentaires, et du profil des utilisateurs. 


User settings Edit Display fields 

Add fields to the user, and arrange them on user display and input forms. 

You can add afield to a group by dragging it below and to the right of the group. 


Label 

Name Field 

Widget 

Operations 

+$*■ User name and password 

User module form element 



History 

User module view element. 



♦f* Timezone 

User module form element. 



Add 

New field 

i 1 

field_ [ 

[ - Select afield type - 0 

- Select a widget - 

Label 

Field name (a-z, 0-9, _) 

Type of data to store. 

Fo mi element to edit the data. 

+$+ New group 




l ] 

group, j 



Label 

Group name (a-z, 0-9, _) 




I Save j 

Figure 16-5 FieldAPI permettra d'ajouter des champs au profil des utilisateurs, 
comme cela etait possible pour les types de contenu. 


URL Projet OraDrup 

► http://www.oracle.com/technology/pub/ 
artides/pedros-drupal.html 


URL Drupal SQL Server compatibility 

► http://drupal.org/node/1394 


URL Pilote PDO pour Oracle 

► http://www.oracle.com/technology/pub/ 
artides/php_experts/otn_pdo_orade5.html 


Un nouveau systeme de base de donnees 

Depuis ses debuts, Drupal evolue pour s’affranchir peu a peu de la base 
de donnees sous-jacente mais il est au final toujours reste bloque sur 
MySQL et PostgreSQL, meme si des projets permettent de rendre 
Drupal 6 compatible notamment avec Oracle et SQLServer. 

Avec Drupal 7, les choses changent radicalement grace a fadoption de 
PDO (PHP Data Objects). PDO est une extension de PHP qui peut se 
comparer dans une certaine mesure a JDBC (Java Database Connecti- 
vity) ou encore a ODBC (Open Database Connectivity). II s’agit dans les 
trois cas d une abstraction d’acces a la base de donnees. 

Les avantages de PDO sont nombreux. Tout d’abord, faudience de PDO 
est plus importante que celle de Drupal, ce qui implique un support plus 
large et plus pousse pour davantage de bases de donnees. II existe deja 
aujourd’hui des pilotes PDO pour MySQL, MSSQL, SQLLite, Firebird, 
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PostgreSQL, ODBC, Oracle, etc. Cela signifie que Drupal, avec la ver- 
sion 7, s’ouvre potentiellement a toutes ces bases de donnees. 

Ensuite, PDO est ecrit en langage compile, on peut done legitimement 
s’attendre a une amelioration des performances d’acces aux donnees. 

Enfin, PDO rend generique des fonctionnements SGBD qui man- 
quaient cruellement a Drupal, comme la gestion des transactions ou la 
prise en charge des architectures redondantes. 

Autres evolutions notables 

Amelioration des performances 

Au regard de Drupal 5, Drupal 6 constitue deja un formidable bond en 
avant en termes de performances. La raison de ce gain a ete fimplemen- 
tation d une technique permettant de ne charger que le minimum de 
fichiers PHP. Avec Drupal 6, chaque module a ete separe en deux lots, 
les fichiers PHP importants et ceux d’usage plus episodique (typique- 
ment fadministration). Ainsi, seuls les fichiers importants sont charges 
lorsqu une page est construite. 

Drupal 7 continue dans cette voie de maniere encore plus radicale en 
mettant en place un registre du code PHP ( code registry). Le principe est 
que Drupal 7 aura connaissance de chacune des fonctions declarees par 
chacun des modules, et ne chargera en memoire que le code strictement 
necessaire a la fabrication de la page. 

Cette nouvelle fonctionnalite permet d’obtenir de meilleures performances 
que Drupal 6, en reduisant sensiblement le temps d 'initialisation de Drupal. 

L’ouverture du moteur de recherche 

Le moteur de recherche actuel de Drupal etant difficile a etendre, une 
nouvelle architecture de recherche est done introduite avec Drupal 7, 
avec pour objectif de faciliter l’integration d’autres moteurs de recherche 
performants, tels que Xapian, Apache Solr, etc. 

Une refonte des droits sur les contenus 

Tous les modules de gestion des droits associes aux contenus que nous 
avons abordes dans cet ouvrage souffrent du meme probleme : leur 
potentielle incompatibility les uns avec les autres. Drupal 7 propose une 
mise a plat de la gestion des droits, qui rendra possible la coexistence 
simultanee de plusieurs modeles. 
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Drupal 6 - Concevoir et deployer ses applications web 


En resume 


• Drupal 7 ne changera rien a vos habitudes. 

• L’ergonomie generale sera considerablement amelioree. 

• L’integration de PDO permet d’imaginer une plus grande ouverture 
vers un plus grand nombre de bases de donnees. 

• Les performances devraient etre encore meilleures que celles de 
Drupal 6. 
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Pour que rinformatique 
soit un outil 

et non un ennemi ! 


Concevoir et deployer 
ses sites web 

Drupal 


La puissance et la modularity 
pour des sites web plus riches 

L’outil libre de publication web Drupal 
dans sa version 6 et 7 a venir est exemplaire 
par son architecture modulaire. Il continue 
de s imposer aux createurs de contenu qui 
doivent construire des sites puissants et 
modernes - du simple blog au site profes- 
sionnel etendu. II permet de gerer des flux 
de contributions complexes, offre une 
grande diversity de types de contenus et 
une interface d administration efficace. 


Yoran Brault est developpeur, architecte et 
expert technique depuis plus de dix ans (notam- 
ment dans les techniques Java/J2EE) et develop- 
peur Drupal depuis plus de 5 ans. Il est lauteur et 
le mainteneur des modules Drupal webDAV et 
FileBrowser, et contribue de fa<;on reguliere au 
forum Drupalfr.org. Createur du site Artisan nu- 
merique en 2004, il a fonde sa societe de services 
arNumeral en 2009 et a participe a la refonte du 
site Mediapart.fr sous Drupal 6. 



Exploitez la puissance de Drupal 
pour construire vos sites web 1 

-4 Comprenez [’architecture de Drupal et reflechissez... 
a quoi faire et ne pas faire avec un CMS aussi puissant 

^ Configurez votre environnement de developpement (WAMP/LAMP) 

^ Administrez Drupal et ses modules, architecturez vos pages 
et proposez plusieurs langues 

^ Gerez vos utilisateurs, les roles des contributeurs 
et flux de publication en toute securite (OpenID...) 

^ Enrichissez les types de contenus: articles, commentaires, 
discussions, FAQ, formulaires et champs, fils RSS, 
filtres et formats... 

^ Modifiez I’apparence avec les themes et personnalisez 
les modeles 

^ Optimisez la charge d’administration par I’automatisation 
des taches recurrentes 

^ Creez votre propre module et evitez les ecueils de la mise 
en production 

^ Evaluez les ameliorations de Drupal 7 


A qui s’adresse cet ouvrage ? 

m Developpeurs web attires par la puissance de Drupal 
m Webmestres qui souhaitent etre guides dans 
la construction de leur site et le choix 
de leurs modules. 
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